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1 
MODULAR UNITARY DISK FILE SUBSYSTEM 


BACKGROUND OF THE INVENTION 


The present invention relates to rotating disk data 
storage peripheral equipment for digital computers. 
More particularly, the present invention relates to a 
miniaturized, plug-in rotating fixed disk file subsystem 
module. 


REFERENCE TO RELATED PATENTS AND 
PATENT APPLICATIONS 


The following U.S. Patents and co-pending patent 
applications are pertinent to the present disclosure: 

U.S. Pat. No. 4,396,959 (now U.S. Pat. No. Re. 
32,075) for Data Transducer Position Control System 
for Ratating Disk Data Storage Equipment; 

U.S. Pat. No. 4,419,701 for Data Transducer Actua- 
tor Control System for Rotating Disk Data Storage 
Equipment; 

USS. Pat. No. 4,516,177 for Rotating Rigid Disk Data 
Storage Device; 

U.S. patent application Ser. No. 06/439,897 filed on 
Nov. 8, 1982 for Aerodynamically Released Safety 
Latch for Data Transducer Assembly in Rotating Rigid 
Disk Data Storage Device; now U.S. Pat. No. 
4,538,193; 

U.S. patent application Ser. No. 06/444,523 filed on 
Nov. 26, 1982, for Improvements in Rotating Disk Data 
Storage Device; 

U.S. patent application Ser. No. 06/728,674 filed on 
Apr. 25, 1985, for Aerodynamic Latch for Disk File 
Actuator; 

U.S. patent application Ser. No. 741,179, filed on the 
same date as this application for Optical Encoder As- 
sembly; 

U.S. patent application Ser. No. 741,178, filed on the 
same date as this application for Compact Head and 
Disk Assembly; 

U.S. patent application Ser. No. 741,588, filed on the 
same date as this application for Microprocessor Con- 
trolled Rigid Disk File Subsystem; 

U.S. patent application Ser. No. 741,174, filed on the 
same date as this application for Improved Optical En- 
coder. 

Disk drives (also known as disk files) have become 
standard equipment for storing and retrieving user data 
in both large and small digital computer systems. Such 
drives have used removable rigid, semi-rigid and flexi- 
ble disks e.g. coated with magnetic media for storing the 
data. Optical data storage techniques are also known. 

Disk drives of the type employed by the present in- 
vention have also used non-removable rotating storage 
disks in sealed, dust free environments in which the data 
transducers fly very close to the storage surface on an 
air cushion or bearing in accordance with what is 
known as “Winchester” technology. These disk drives 
store and retrieve data in concentric data tracks formed 
on the major surfaces of the data storage disk. Such 
non-removable or “fixed” disk based drives are able to 
store a significant amount of user data on each storage 
surface, such as five million bytes of user data per stor- 
age surface. 

By moving the data transducers radially relative to 
the rotating disks with electromagnetic disk actuator 
mechanisms, disk drives are able to gain access to any 
data location within a very short period of time. Thus, 
such drives combine the features of substantial data 
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2 
storage capacity and random rapid access to any se- 
lected concentric track containing the stored data. 

Traditionally, disk drives have been bulky and have 
required multiple separate subparts: an enclosed head 
and disk assembly; control electronics for the head and 
disk assembly, usually packaged with the head and disk 
assembly, a controller for controlling the formatting of 
the data storage surface and for thereafter controlling 
each data storage (write) and retrieval (read) operation 
performed by the drive; and an interface, for interfacing 
both the controller and the drive contro] electronics to 
the host computer, so that its operating system may use 
the drive effectively as a data storage resource available 
to the computer user. 

Small computer systems, sometimes referred to as 
“personal computers” and as exemplified by the IBM 
Personal Computer TM, typically provide attachment 
locations and electrical connections for a few accessory 
circuit cards. These accessory cards may provide disk 


20 drive controller, video display, modem, additional 
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memory, and other functions. Usually the space allo- 
cated for such accessory cards is narrow (one inch 
across) and elongated. Also, the power supply available 
for such additional accessories is quite limited. 

One significant drawback of the traditional approach 
has been that the use of separate circuits for the control 
electronics, controller and interface has led to redun- 
dancies of circuitry, particularly control, address and 
data buffers, and consequent high power consumption 
levels. These power consumption levels have required 
host computer systems to be designed to supply the 
required higher levels, or have required separate or 
special power supplies to be used. 

One other significant drawback of the traditional 
approach has been the physical space required to house 
the head and disk assembly, its control electronics, the 
controller and the interface. When separate housings 
have been employed, significant drawbacks have been 
the clutter presented by the multiple housings and re- 
quirement that housings be cabled together with cables 
carrying a large number of conductors. Such cablings 
and plugs, extending outside of the housings, are ex- 
posed and have been known to fail, thereby rendering 
the disk drive subsystem inoperative and useless until 
repaired. Also, multiple housings have complicated the 
portability of small personal computer systems. 

Fixed disk drive head and disk assemblies do not lend 
themselves to home or field repairs. The disk drive 
enclosure may only be opened safely for inspection and 
service in a “clean-room” environment. Thus, the ser- 
vicing of small fixed disk files usually goes on in the 
factory or at one or a few central service locations. 

In light of these and other drawbacks known to those 
skilled in the art, a hitherto unsolved need has arisen for 
a fully integrated, highly miniaturized, very low power 
rotating non removable disk data storage subsystem 
module for direct plug-in attachment to and use within 
small host computer systems, typically of the “personal 
or professional computer” (single user) type, without 
use of any cabling and without any modification of the 
host beyond plugging in the modular subsystem. 

SUMMARY OF THE INVENTION WITH 
- OBJECTS 

A general object of the present invention is to minia- 
turize and to integrate a complete disk file’subsystem 
into a small unitary module for direct plug-in attach- 
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ment to and removal from a host computer system in a 
manner which overcomes the limitations and draw- 
backs of prior art disk file subsystems. 

A specific object of the present invention is to pro- 
vide a miniaturized, fully integrated disk drive subsys- 
tem in a flat, elongated form factor for plug-in attach- 
ment to a single user computer so as to occupy a single 
accessory jack location provided in the computer for 
attachment of accessories. 

A further object of the present invention is to provide 
a miniaturized and fully self contained unitary disk file 
subsystem for direct plug-in attachment to a host com- 
puter of the single user type without requiring any hard- 
ware modification of the computer. 

One more object of the present invention is to pro- 
vide a miniaturized and fully self contained unitary disk 
file subsystem which may be plugged into and used with 
a host computer of the single user type by the computer 
user without requiring any special skills or special tools 
for the installation or for use. 

A further object of the present invention is to provide 
a compact and efficient electronic control system which 
uses a single microprocessor to supervise operations of 
the disk file. 

A modular unitary disk file subsystem for a host com- 
puter incorporating the principles of the present inven- 
tion includes a thin, compact, and enclosed .radially 
movable head and fixed rotating disk assembly. An 
elongated, planar support substrate is provided for 
mounting and supporting the head and disk assembly 
and for mounting, carrying and connecting electronic 
circuit elements for moving the head radially relative to 
the disk. The electronic circuit elements are provided 
for controlling data storage operations for storing and 
retrieving data from among selected concentric data 
tracks formed on a data storage surface of the fixed 
rotating disk through the head, and for interfacing the 
disk file subsystem with the host computer. The support 
substrate further includes a connector at a single loca- 
tion thereon, the connector being provided for obtain- 
ing power, control and data signals from the host com- 
puter, and for supplying control, status and data signals 
to the host computer. Thus, the support substrate 
thereby carries and interconnects the subsystem with 
the host computer as a direct plug-in unit within the 
housing of the host, without any cabling between the 
host and the subsystem. 

These and other objects, advantages and features of 
the present invention will become more apparent from 
the following detailed description of a preferred em- 
bodiment, presented in conjunction with the accompa- 
nying drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 


In the drawings: 

FIG. 1 is an exploded isometric and somewhat dia- 
grammatic view of a compact, modular disk file subsys- 
tem including a mounting frame, the subsystem being in 
accordance with the principles of the present invention. 

FIG. 2 is an exploded isometric and somewhat dia- 
grammatic view of the subsystem of FIG. 1 wherein a 
printed circuit substrate is extended and provides the 
mounting substrate for the head and disk assembly. 

FIG. 3 is a somewhat diagrammatic and exploded 
view in perspective of an assembly of the elements 
comprising the head and disk assembly incorporating 
the principles of the present invention. The elements 
depicted in FIG. 3 have been dispersed along broken 
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explosion lines to facilitate illustration of the head and 
disk assembly. 

FIG. 4 is an exploded diagrammatic view in perspec- 
tive along a single central axis of explosion of the struc- 
tural elements comprising a compact optical encoder 
subassembly incorporated within the head and disk 
assembly depicted in FIG. 3. 

FIG. 5 is a diagrammatic top plan view of the head 
and disk assembly depicted in FIG. 3, showing the 
elements thereof in place, except for the upper magnet 
and flux return plate, and certain flexible connection 
substrates which have been omitted to facilitate clarity 
of explanation and understanding. 

FIG. 6 is a longitudinal view in side elevation and 
section of the assembly of FIG. 3 through the axis of 
rotation of the spindle motor. The section is along the 
line 6—6 in FIG. 5. 

FIG. 7 is a diagrammatic bottom plan view of the 
head and disk assembly depicted in FIG. 3. 

FIGS. 8A, and 8B are respectively an electronic 
schematic circuit diagram of the three phase, brushless 
spindle motor depicted in FIG. 3 and an electronic 
schematic circuit diagram of a driver circuit needed to 
operate and commutate the brushless DC spindle mo- 
tor; and, a bottom or inside plan view of one preferred 
layout of a small circuit module for carrying the cir- 
cuitry depicted in FIG. 8A. 

FIG. 9 is an enlarged top plan view of a rotary actua- 
tor element of the the head and disk assembly depicted 
in FIG. 3. 

FIG. 10 is a diagrammatic view in side elevation and 
section of a portion of the rotary actuator motor, taken 
along the line 10—10 in FIG. 4. 

FIG. 11 is an electrical block diagram of the control 
electronics for the disk file subsystem depicted in FIG. 
1 


FIGS. 12a through 12/ are nine sheets of drawing 
which together set forth a single electrical circuit sche- 
matic diagram of the electronics for the disk file subsys- 
tem depicted in FIG. 1. FIG. 12 is a layout plan for the 
nine sheets of FIGS. 12a through 12; and explains how 
these sheets should be arranged together in order to 
provide the overall single electrical schematic. 

FIGS. 13A, 13B and 13C are respectively an electri- 
cal circuit schematic, a block diagram of a two channel 
monolithic read/write and head select circuit and a thin 
film flexible circuit substrate mounted within the head 
and disk assembly shown in FIG. 3, and which plugs 
into the read and write circuitry depicted in FIG. 12A. 

FIG. 14 is a detailed block diagram of the structure of 
a data sequencer included within the circuitry shown in 
FIG. 11. 

FIG. 15 is a detailed block diagram of the structure of 
a memory controller included within the circuitry 
shown in FIG. 11. 

FIG. 16 is a detailed block diagram of the structure of 
an input/output channel interface included within the 
circuitry shown in FIG. 11. 

FIG. 17 is a detailed schematic and block diagram of 
the structure of an analog/digital servo circuit included 
within the circuitry shown in FIG. 3. : 

FIG. 18 is a detailed schematic diagram of an optical 
encoder circuit carried on the flexible circuit substrate 
depicted in FIG. 4. 

FIG. 19 is a detailed schematic and block diagram of 
a data separator element included within the circuitry 
shown in FIG. 11. 
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FIG. 20 is a diagram of track formatting followed in 
the disk file subsystem depicted in FIG. 1. 


DETAILED DESCRIPTION OF A PREFERRED 
EMBODIMENT 


As seen in FIGS. 1 and 2 a miniaturized rotating fixed 
disk data storage subsystem 5 includes in FIG. 1 a 
printed circuit card 6 carrying substantially all of the 
highly modularized and integrated electronic circuits 
required to operate the subsystem 5, and an elongated 
frame 7 (shown in FIG. 1). The printed circuit card may 
be strengthened and elongated and be used as a support- 
ing substrate 6c in lieu of the frame 7, as shown in FIG. 
2. A mounting flange 8 formed as a part of the frame 7 
(FIG. 1), or attached to the circuit card 6A by screws 
(FIG. 2), enables the subsystem 5 to be mounted in and 
occupy a single accessory slot location of a single user 
computer, such as the IBM Personal Computer TM , for 
example and thereby achieve a direct plug-in electrical 
attachment thereto. 


Head and Disk Assembly 10 


A thin and compact head and disk assembly 10, de- 
picted i in detail in FIGS. 3-10 and discussed hereinafter, 
is attached to the frame 7 (FIG. 1) or to the printed 
circuit board 6 (FIG. 2) via mounting hardware 9 which 
provides for some insulation of the assembly 10 from 
physical shocks to the host. 

In FIG. 3, the assembly 10 is shown as including a 
housing 12, which functions to enclose, align, and/or 
support all of the other elements included as part of the 
assembly 10. The housing 12 is preferably formed as a 
metal casting, such as of aluminum. The housing 12 may 
also be formed from stock by machining, and may also 
be formed by sintering of formed powdered metal, in 
accordance with known technology. A continuous 
outer peripheral wall 11 and recesses 13 (FIG. 7) serve 
to reinforce the housing 12 and also to minimize the 
amount of material required in its fabrication. 

A cover 14 attaches to the housing 12 via screws 15 
and thereby encloses the interior thereof. A gasket 16 
seals the interior of the housing 12 from the ambient, 
and prevents intrusion of foreign particulate material, 
such as dust, which would interfere with the operation 
of the assembly 10. A breather filter 17 enables the 
pressure inside the housing 12 to equalize to exterior 
ambient. Two ports 18 are provided through the cover 
14 to enable the interior to be purged of dust particles 
during the manufacturing operation. Seals 19 seal the 
two ports 18 after purging. 

A micropore air filter 20 is mounted in one corner 21 
of the housing 12 and filters internal air to remove any 
particulate contamination during operation. 

The head and disk assembly 10 includes three major 
elements or subsystems: an optical encoder subassembly 
100 described in connection with FIG. 4; a disk, spindle 
and direct drive spindle motor subassembly 200 de- 
scribed in connection with FIGS. 3 and 6-8, and a ro- 
tary actuator and motor subassembly 300, described in 
connection with FIGS. 3, 5, 6, 8, and 9. 


Optical Encoder Subassembly 100 


The encoder subassembly 100 includes three major 
parts. The first part is a moving scale 112 having alter- 
nating light translucent and opaque radial microlines 
113. The scale 112 is mounted on a ledge 302 of a sub- 
stantially planar rotary actuator frame 304 of limited 
angular displacement which is rotatably journalled to 
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6 
the housing 12 as shown in FIGS. 3 and 5, and discussed 
hereinafter in greater detail, Thus, in this preferred 
embodiment the scale 112 is also of limited angular 
displacement, limited to a maximum of approximately 
thirty degrees of arc (30°). 

The second part of the encoder 100 is a unitized en- 
coder structure 114 comprising a light source holder 
116 carrying an LED light source 118 and a mirror 120, 
a photocell array carrier 122 carrying and aligning a 
photocell array 124 and an overlying mask or reticle 
126, a support bolt 128 having a widened circular head 
or table top 130 for mounting the light source holder 
116 and the photocell array carrier 122 and having a 
threaded cylindrical shank 132. A wave spring washer 
134 is interposed between the shank 132 and an annular 
machined plateau 136 surrounding a cylindrical opening 
formed through a bottom wall portion 138 of the hous- 
ing 12. The cylindrical opening is sized to receive the 
shank therethrough in a freely rotating relationship. A 
locking nut 140 threads onto the shank 132 after it is 
passed through the base portion 138 so as to secure the 
bolt 128 and the other elements it carries to the base 
portion 138. The photocell array 124 includes an upper 
photocell 124A, a lower photocell 124B, and an AGC 
cell 124C located between the two photocelis 124A and 
L2AB. 

The LED light source holder 116 is secured to the 
support bolt 128 by screws 172 which pass through the 
holder 116, and also through the photocell array carrier 
122 and into threaded openings 194 provided in the 
rai 130 of the support bolt 128, as shown in FIG. 


ae photocell array carrier 122 includes a central 
well 123 in which the photocell array 124 is mounted. A 
small printed circuit board 186 is provided adjacent to a 
connection edge of the photocell array 124. Fine wires 
are then bonded between connection pads of the array 
124 and corresponding traces of the circuit board 186. 
The reticle 126 is then directly mounted over the photo- 
cell array 124 in precise optical alignment, so that open- 
ings in the reticle 126, in cooperation with the radial 
microlines 113 of the scale 112, enable generation of 
polyphase incremental position electrical signals which 
are related to the position of the actuator frame 304 
relative to the housing 12. 

The threaded shank 132 of the bolt 128 passes 
through the housing at the location shown in FIGS. 3 
and 7. The bolt 128 includes a slot 174 (FIG. 7) which 
enables the encoder assembly 114 to be rotated during 
final assembly and optical alignment in the housing 12. 
The nut 140 enables the assembly 114 to be locked at a 
precise height relative to the scale, by virtue of com- 
pression of the wave spring washer 134. The nut 140 
includes two transverse grooves 176 at its threads. 
These grooves 176 enable the nut 140 to be glued effec- 
tively to the bolt 128 and to the housing 12 once proper 
alignment of the encoder and scale is achieved during 
the manufacturing process. 

The third part of the subassembly 10 is an electronic 
circuit 142 which is preferably formed of electronic 
components secured to a flexible film printed circuit 
substrate 144. The substrate 144 is adapted to be placed 
inside the housing 12 adjacent to the encoder subassem- 
bly 100, in a well generally designated by the reference 
numeral 154 in FIG. 5. 

The substrate 144 includes three integral flexible con- 
nection extensions, a first extension 146 enabling con- 
nection to the photodetector array 124 via the small 
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circuit board by screws 156 at the locations indicated by 
the broken lead lines in FIG. 4. A second extension 148 
extends to and enables connection of the circuit 142 to 
the LED light source 118, and a third extension 150 
includes a suitable plug 152 for enabling direct overall 
electrical connection of the subassembly 110 to the disk 
drive control electronics circuit card 6, 62 with which 
the head and disk assembly 10 may be used. This con- 
nection via the plug 152 is external to the housing 12, 
and the thin film extension 150 passes between the hous- 
ing 12 and the gasket 16 to the external connection 
location, with the electrical traces being adjacent to the 
insulating gasket 16 and with the mylar substrate being 
against the lip of the housing 12. 


Optical Encoder Circuit 142 


As depicted schematically in FIG. 18, an integrated 
circuit U1 contains four operational amplifiers U1A, 
UIB, UIC and U1D. The amplifier U1A is a current to 
voltage converter and has an inverting input connected 
to the anode of the upper photocell 124A of the photo- 
detector array 124, and the amplifier U1B is a current to 
voltage converter having an inverting input connected 
to the anode of the lower photocell 124B of the array. A 
negative feedback circuit comprising a capacitor C4 
and a resistor R12 adjusts the frequency response and 
gain of the converter U1A, and a similar but adjustable 
network of capacitor C3 and series resistors R9 and R10 
adjusts the frequency response and gain of the con- 
verter U1B. The resistor R10 is variable, so that the gain 
characteristics of U1B may be made the same as those 
for the converter U1A. 

A reference voltage Vref is derived from a 12 V 
supply bus from the host computer through a network 
comprising a series resistor R3 and 5.0 volt zener diode 
CR1. The zener regulated 5.0 volts is applied to the 
non-inverting input of an operational amplifier U1C. A 
resistance network of resistors R2 and R1 provide at a 
common node a feedback path to an inverting input of 
the amplifier U1C and a reference voltage Vref which 
connects to the common cathode substrate of the photo- 
detector array 124 via a connector J2-2. The values of 
the resistors R1 and R2 establish the voltage present at 
the output of the amplifier U1C. This output voltage is 
supplied to two adjustable networks: the first network 
comprising the resistors R16, R17 and R18 for control- 
ling the operation of the converter U1A, and the second 
network comprising the resistors R13, R14 and R15 for 
controlling the operation of the converter U1B. Resis- 
tors R18 and R15 are individually adjustable so that the 
electrical characteristics of the photocells 124A and 
124B respectively may be individually controlled and 
equalized in terms of voltage output over the range of 
light to dark. These two adjustments R18 and R15 also 
enable each photocell 112, 114 of the polyphase encoder 
100 to be trimmed to accomodate the gap 
between the scale 112 and the mask 126 without loss of 
current amplitude between the maxima of light and dark 
conditions at each photocell. 

An automatic gain control (AGC) cell 124C of the 
array 124 is connected to an inverting input of an opera- 
tional amplifier U1D via a connector J2-31. The non- 
inverting input of the amplifier UD is connected to the 
Vref node. The output of the amplifier U1D is con- 
nected to a driver transistor Q1 which in turn supplies 
current from a 5 volt bus of the host equipment to the 
anode of the LED light source 118. The cathode of the 
light source is connected through two current limiting 
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resistors R4 and R5 to ground. A series network of 
resistors R6 and R7, in combination with the current 
put out by the AGC photocell 124C controls the cur- 
rent put out by the operational amplifier UID and actu- 
ally applied to the LED through the driver transistor 
Q1. R6 is adjustable to control quiescent current 
through the LED 118. 


Disk and Spindle Motor Subassembly 200 


The disk and spindle motor subassembly 200 includes 
a very thin and flat direct drive, brushless spindle motor 
202 which mounts in a well 204 of the housing 12 by 
three screws 205. The screws 205 pass through open- 
ings in a peripheral flange 206 of the motor 202 which 
mates with a machined annular surface 208 adjacent to 
the open well 204. The lower surface of the flange 206 
and the facing surface 208 of the housing 12 are ma- 
chined, so that the motor 202 is thereby sealed in an 
airtight arrangement with the housing 12. 

The motor 202 includes a rotating hub 210 which has 
a lower flange 212. A data storage disk 214 mounts over 
the hub 210 and against the flange 212. The flange 212 
has a height adapted to align the data disk 214 properly 
within the interior of the housing 12. The disk 214 is 
coated on both major surfaces with a magnetic storage 
material such as a ferrous oxide or plating and provides 
the storage medium of the compact head and disk as- 
sembly 10. In the preferred embodiment, the disk has a 
diameter of approximately 95 millimeters, and has the 
capability of easily storing in excess of ten million bytes 
of formatted data. 

An airflow generator disk 216, preferably formed of a 
low-mass plastic material, attaches to the top of the hub 
210 by a single axial locking screw 218. Storage capac- 
ity may be doubled by replacing the airflow generator 
disk 216 with a second magnetic media data storage disk 
215 and by adding additional data transducers and sup- 
port arms to the rotary actuator assembly 300. A second 
data storage disk 215 is shown diagramatically in FIG. 
11. Two opposed peripheral openings 220 through the 
disk 216 align with two openings 222 on the top of the 
hub 210. A spanner wrench is used to prevent the hub 
210 from rotating while the screw 218 is tightened. The 
spanner wrench is provided with two pins aligned with 
the openings 220 and 222. The pins pass through the 
openings 220 and 222 and thereby align the top disk 216 
and the hub 210 as the screw is locked into place. A 
spacer 213 between the top disk 216 and the data disk 
214 locks the data disk 214 against the lower flange 212. 

The top surface of the spindle motor 202 includes a 
recessed and shielded region 224, in which an electro- 
magnetic shield is placed, in order to prevent contami- 
nation of data stored on the lower surface by the elec- 
tromagnetic fields generated inside of the motor 202. 

As seen in FIG. 5, an aerodynamically released ship- 
ping latch 230 is rotatably mounted on a vertical post 
232 (FIG. 3) in the housing 12. A vane 234 and flag 236 
of the latch 230 are deflected by airflow generated by 
clockwise rotation of the disks 214 and 216. The airflow 
is sufficient to overcome the force exerted by a bias 
spring (not shown) which urges the latch 230 in a clock- 
wise direction. A notch 238 provided in a counter- 
weight 306 of the rotary actuator 300 is engaged by a 
finger 240 when there is no rotation of the disks 214 and 
216 (and no airflow). This arrangement latches the ro- 
tary actuator 300 into a landing zone position. 

When power is removed from the head and disk 
assembly, the counter electromotive force generated by 
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rotation of the spindle motor 202 in response to the 
inertia stored in the motor 202, spindle 210 and disks 
214, 216, is automatically applied to the rotary actuator 
300 in order to return the actuator to the landing zone 
position before disk rotation ceases and the aerody- 
namic latch 230 is no longer deflected by airflow. This 
electronic return spring feature is described hereinafter, 
in connection with the electrical circuit elements. 

One important requirement for the head and disk 
assembly 10 is that the spindle 210 be effectively 
grounded to the frame. Ordinarily, an electrical brush 
makes contact between the spindle shaft and the hous- 
ing external to the motor. However, such arrangement 
adds significantly to the height of the motor and to the 
overall thickness of the head and disk assembly. Thus, it 
has been discovered that a grounding mechanism 250 
(FIG. 6) may be placed entirely within the spindle shaft 
252 of the motor 202. 

The preferred mechanism includes a spring loaded 
ball or tip 254 inside the hollow spindle shaft 252. The 
tip 254 is of conductive material, such as a carbon im- 
pregnated plastic resin material, and it makes direct 
contact with a pad 256 of highly conductive hardened 
material such as stainless steel which is fixed and con- 
nected to the stationary enclosure 258 of the motor 202. 
The enclosure 258 is grounded to the housing 12 at the 
peripheral flange 206 by the screws 205. 

One important aspect of the present invention is that 
the electronic circuitry required to drive the multiple 
windings of the spindle motor 202 be sinked directly to 
the housing. The arrangement shown in FIG. 7 makes 
direct heat sinking of the driving circuitry to the hous- 
ing 12 possible. In FIG. 7, a small printed circuit mod- 
ule 260 plugs into a cable 262 from the motor 202 and 
also plugs into the circuit board 6 externally of the head 
and disk assembly 10 via a cable 264 disposed in a chan- 
nel 266 formed in the back of the housing 12. 

An integrated circuit motor driver 268 such as type 
HA 13426 supplied by HITACHI America, Ltd., Chi- 
cago, Il. 60006 having its pins connected to the circuit 
board 260 as shown in FIGS. 7 and 8A, includes a 
flange 270 which is directly mounted to the back of the 
housing 12 in a well 272 formed in the housing with a 
sufficient depth from the lower surface profile in order 
to hold the circuit board 260 and its components (FIG. 
8B) most of which are located on the underside of the 
board 260. Screws 272 secure the heat sink flange 270 of 
the integrated circuit directly to the housing 12 inside 
the well 272. 

The circuitry for the three phase motor 202 is de- 
picted in FIG. 8A, which indicates that the motor is Y 
wound and generates three phase commutation signals 
by three Hall effect generators U, V, W responsive to a 
small permanent magnet disposed in the rotating perma- 
nent magnet in the armature of the motor, as is conven- 
tionally known and understood. A fourth Hall effect 
transducer I generates and puts out a once per revolu- 
tion index signal which is ultimately supplied to the 
control electronics external to the head and disk assem- 
bly 10. 

A bottom or inside plan view of the modular circuit 
board 260 (FIG. 8B) indicates one acceptable form of 
layout for the discrete components on the circuit board 
260, in which all but two of the discrete components are 
mounted between the printed circuit board and the 
facing bottom wall of the housing 12. This arrangement 
protects these components from physical harm, and it 
enables ready attachment of test equipment should trou- 
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10 
bleshooting of the circuit carried on the module 260 
ever be required. Also, the cables plug into the circuit 
module 260, enabling it to be removed and replaced 
very easily, without disturbing any other circuitry, and 
without any need to enter the dust-free housing 12. 


Rotary Actuator Subassembly 300 


The third major subassembly of the head and disk 
assembly is a very flat and thin rotary actuator subas- 
sembly 300, depicted in various levels of detail in FIGS. 
3, 5, 6, 7, 9 and 10. As already mentioned, the actuator 
300 includes a planar frame 304, preferably formed of 
cast or stamped aluminum. The frame 304 includes four 
regions. The region 302 for supporting the scale 112 of 
the optical encoder 100 has already been discussed. 

A second region of the frame 304 is for aligning and 
supporting a triangular electromagnetic coil 307 of a 
single winding 308 whose two ends are connectable at 
connection pins 310. The coil 307 is wound on a bobbin 
and is then integrally molded to the frame 304 with a 
suitable molding compound 311. Regions 312 denote 
holes passing through the frame 304 which are filled 
with potting material during the molding process, so 
that the coil 307 may be precisely aligned both radially 
and in the planar dimension relative to the frame 304. 

A third region of the frame 304 provides a support 
extension 314 for two arms 316, 318 supporting respec- 
tively two oppositely facing “flying head” data trans- 
ducers 320, 322 which are disposed in proximity to the 
two major, data storage surfaces of the data disk 214, as 
shown in FIG. 6. During rotation of the disk 214, the 
transducers 320, 322 ride or “fly” upon an air bearing in 
very close proximity to the data surface in accordance 
with what is known as “Winchester” technology. 

The fourth region of the frame 304, already men- 
tioned, supports the counterweight 306, whose mass is 
selected to counterbalance the other regions of the 
frame 304, and also to cooperate with the aerodynami- 
cally released shipping latch 230, also previously ex- 
plained. The counterweight 306 is attached to the frame 
304 by screws 309. 

The actuator frame 304 includes a central opening 
301 which reduces its mass and inertia, and which pro- 
vides a convenient location for a single crash stop post 
313 which is adapted to engage oppositely facing sur- 
faces 315, 317 formed on the inside walls of the frame 
304 which define the opening 301. The post 313 is press 
fit into a suitable opening 319 in the housing 12. A cylin- 
drica] rubber gasket 321 slips over the post 313 and 
dampens the impact of the frame 304 upon the post 313. 
The crash stop post 313, in combination with the arc 
length between the surfaces 315, 317, limits the dis- 
placement of the actuator 300 to a predetermined maxi- 
mum. This limitation of displacement is essential to 
prevent the transducers from coming off of the data disk 
214, and from crashing into the lower flange 212 of the 
spindle hub 210. 

A rotary actuator spindle includes a fixed shaft 324 
mounted upwardly from the housing 12. A washer 326, 
a lower bearing 328, a spacer 330, a wave spring washer 
332, an upper bearing 334 and a locking washer 336 and 
screw 338 all cooperate to provide a freely rotating 
journal for the actuator frame 304. These elements are 
mounted and contained in an axial cylindrical opening 
340 provided through the frame 304 and enable the 
frame 304 to move across an arc of approximately thirty 
degrees and thereby move the transducers radially 
across the data surfaces of the data disk 214 so that each 
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of the multiplicity of concentric data tracks formed on 
each data surface of the disk 214 may thereby be ac- 
cessed by operation of the rotary actuator 300. 

A lower flux-return magnet plate 350 carrying a 
lower permanent magnet 352 is mounted to the housing 
12 by screws 353; and, an upper flux-return magnet 
plate 354 carrying an upper permanent magnet 356 is 
mounted to the housing 12 by screws 357. As seen in 
FIG. 10, the coil 307 is disposed between the two oppo- 
sitely facing permanent magnets 353 and 356. 

Each magnet 352, 354 is magnetized to have two 
regions of pole reversal. The magnetic poles are at the 
major surfaces of the magnets 352, 354, and are comple- 
mentary with each other so that a very strong flux 
region exists in the gap between the two opposed faces 
of the two magnets 352 and 356 (FIG. 10). A polar 
reversal region 358 generally bisects each magnet 352, 
354. This is so that the effect of the flux on e.g. the left 
side (FIG. 10) on the coil 307 with current passing 
through its adds to the effect of the flux on e.g. the right 
side, since current will be passing through the single 
winding 308 in one direction only. 


Head Select and Amplifier Circuitry 


A thin, highly flexible mylar circuit connection film 
360 is provided for direct connection to the data trans- 
ducers 320, 322. This elongated, highly flexible and 
durable connector film 360 extends from a larger flexi- 
ble mylar printed circuit 362 which is preferably 
mounted on the upper flux return plate 354 and which 
carries some of the read and write drive circuitry and 
head select circuitry required for operating the trans- 
ducers 320, 322. A plan view of the circuit 362 is de- 
picted as FIG. 13C. A connection extension 364 for the 
mylar circuit 362 extends outwardly from the drive 
between the gasket 16 and the upper face of the periph- 
eral wall 11 along the same lineal edge thereof as passes 
the connection portion 150 for the optical encoder sub- 
assembly 100. The electrical circuit diagram of circuit 
elements and connections for the circuit carried by the 
film is depicted FIG. 13A. Therein, a monolithic inte- 
grated circuit 366 provides a six channel (six head trans- 
ducer) head select and amplification function (FIG. 
13B). Only two head select channels, H4 and H5, are 
active in selecting between the heads 320. 322 of the 
subsytem 5 (see FIG. 13a); if an additional data storage 
disk 215 is used, then four channels are active in the 
head select operation. This circuits 366, is preferably a 
type SSI 117, made by Silicon Systems Incorporated, or 
equivalent. 

Circuit Card 6 

Four flexible circuit substrates extend from the head 
and disk assembly 10. These substrates may be conduc- 
tive traces formed upon thin, flexible mylar film, or they 
may be thin and flat wire cables. In any event, one leads 
to a jack 349 for connecting internal head read/write 
electronics with an external read/write channel, an- 
other leads to the jack 152 for connecting the optical 
encoder subassembly 100 with an external analog/digi- 
tal servo element, another leads to a jack 353 for con- 
necting the spindle motor control module 260 with the 
circuit board 6 circuitry, and a final one 355 leads from 
the coil 307 of the rotary head positioning actuator 300 
within the head and disk assembly 20 to external drive 
electronics, being part of the analog/digital servo ele- 
ment. 
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The small double sided printed circuit card 6 carries 
all of the electronics required for the control system of 
the present invention (except for the circuits within the 
head and disk assembly which have already been men- 
tioned). 

The circuit card 6 includes a conventional edge con- 
nector region 365 having properly aligned connection 
traces 367 for engaging corresponding contact pins of 
an accessory or peripheral circuit card connector of the 
system board or mother board of the personal computer 
(host system) in which the storage subsystem 5 is in- 
stalled and connected solely via the traces 367 on the 
edge connector region 365. 

Four plugs 369, 371, 373 and 375 are provided on the 
circuit card for receiving respectively the jacks 349, 
152, 353 and 355, previously described. These plugs 
enable the circuitry inside the head and disk assembly 10 
to extend to and be connected to the circuitry carried 
on the circuit card 6 and to be supplied with power 
from the host system via the edge connector 365. 


Electronics Overview 


The following major circuit elements are contained 
on the printed circuit card 6 generally in the positions 
indicated in FIGS. 1 and 2. (These circuit elements are 
interconnected in accordance with the architectural 
overview of FIG. 11 and in accordance with the de- 
tailed connection diagram made up of FIGS. 122 
through 12i, as arranged and read together in accor- 
dance with the FIG. 12 layout plan. 


Microcomputer 381 and Program Memory 383 


A single programmed, sequential state monolithic 
microcomputer 381, sometimes referred to as a “micro- 
processor”, provides overall control of the subsystem 5. 
The microcomputer 381 is preferably a type 7810, man- 
ufactured by NEC Corporation, of Japan, or equivalent. 
The microcomputer 381 includes a single central pro- 
cessing unit (CPU) and a single arithmetic logic unit 
(ALU), as well as other internal supporting architec- 
ture. It executes only one instruction at a time. 

The type 7810 is a single chip, five volt, eight bit 
microcomputer including an internal analog to digital 
converter having eight multiplex-selectable analog in- 
puts. The analog to digital converter operates continu- 
ously by converting whatever voltage appears at a se- 
lected input into a digital value which may be read at 
any time by the microcomputer 381 under program 
control. 

The microcomputer 381 also includes a 256 by eight 
bit RAM, multifunctional timer/event counters, general 
purpose serial and parallel interfaces and input/output 
ports, and maskable and non-maskable interrupt capa- 
bility. The microcomputer 381 may also control exter- 
nal memory directly, and requires an external program 
memory for containing the instructions which it is to 
execute in carrying out the supervisory functions of the 
control system of the present invention. Each instruc- 
tion cycle requires one microsecond, and the basic 
clocking frequency for the microcomputer 381 is 12 
MHz. The software controlled functions of the mi- 
crocomputer 381 are discussed in greater detail subse- 
quently herein. 

The microcomputer 381 utilizes a multiplexed bus 
structure, so that the same electrical lines may carry 
both address information and data information, at dif- 
ferent times. These times alternate, so that in one ma- 
chine cycle, a bus may be carrying addressing informa- 
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tion, and at the next cycle, the same bus may be carrying 
data information, and so forth. 

The 256 byte random access memory within the mi- 
crocomputer 381 is used as a stack and provides all of 
the general purpose registers required for operations of 
the microcomputer. 

An eight kilobyte external read only program mem- 
ory 383 is connected to the microcomputer 381, and it 
contains the instructions which the microcomputer 381 
will execute during operations of the disk file subsystem 
331. These instructions are presented as a listing at the 
end of this specification. 

The microcomputer 381 is the heart of the control 
system and has two overall tasks: it supervises and con- 
trols radial head position via an electromagnetic voice 
coil actuator 300 of the head and disk assembly 10 via 
servo control loops, and it responds to commands from 
the host computer system by initiating and monitoring 
transfers of blocks of data to and from the host and the 
disk data storage surfaces via the controller/interface. 

It is important to remember that throughout the data 
read/write operations and data transfer operations the 
microcomputer 381 is monitoring the progress of such 
operations and it is simultaneously controlling the track 
following head position servo loop so that it is tightly 
servoing the heads 320, 322 at the centerline of the track 
at which data is being read or being written. 


Track Positioning and Following Servos 


The subsystem servo performs two functions: First, it 
must hold read/write data transducer heads in align- 
ment with the centerline of each data track during track 
following operations. Second, it must be able to per- 
form track seeking operations which cause the heads 
320, 322 to- be moved rapidly and accurately from a 
known departure track location to a desired destination 
track location. All servo operations are controlled and 
supervised by the microcomputer 381 which controls 
the current which passes through the coil 308 of the 
voice coil actuator 300. 

An analog/digital servo circuit 385 is connected to 
the microcomputer 381, and the circuit 385 provides 
circuit elements which are required to carry out servo 
control loop functions in data track seeking and track 
following operations of the head and disk assembly. 
This monolithic circuit 385 is explained in greater detail 
in conjunction with FIG. 18 hereinafter. 

The optical encoder assembly 100, previously de- 
scribed, responds to relative light levels indicative of 
position of the scale 112 and converts the light levels 
into two phase signals P1 and P2 which are in phase 
quadrature. These phase signals are converted to volt- 
ages by the current to voltage converters U1A and U1B 
of the assembly 142 and are then supplied to the analog 
to digital converter within the microcomputer 381, via 
the analog/digital servo chip 385. The circuitry of the 
encoder is set forth and discussed herein in greater 
detail in conjunction with FIG. 18. 

The analog/servo chip 385 and related circuitry con- 
verts digital position values to driving currents and 
applies these currents through driving circuitry 390 toa 
winding 308 of the rotary actuator 300, symbolized in 
FIG. 11 by the broken line carrying reference numeral 
300 and interconnecting a symbolic data transducer 
head 320, and the moving scale 112. The direction and 
magnitude of current passing through the coil 308 de- 
termines the direction and velocity of the head 320 in 
moving among concentric data tracks formed on the 
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14 
data storage major s surface of the data storage disk 214, 
The servo circuit 385 is described hereinafter in greater 
detail in connection with FIG. 17. 


Storage Disk 214 


The disk 214 (and 215 in a 20 megabyte version of the 
subsystem 5) includes two major data storage surfaces 
2140 and 2145 coated with a suitable magnetic data 
storage material. Each data storage surface provides 
storage room for a multiplicity of concentric data stor- 
age tracks, there being some 612 logical tracks available 
per data surface. Some 24 additional spare tracks are 
provided at the outer periphery of the disk surface 214a, 
2145 to be used in place of tracks having media defects 
so that the first tracks required by the host’s operating 
system for directory purposes will be free of defects, 
and thereby be reliable in all cases. 

An inner landing zone region LZ is provided so that 
the ferrite slider head 320, 322 comes into actual contact 
with its underlying data surface 214a, 2144, and subjects 
it to possible abrasion only in the landing zone region 
LZ. Each concentric data track nominally holds ap- 
proximately 10,416 bytes, and is divided into eighteen 
data sectors, seventeen of them being for storage of 
useful data and one of them being held in reserve in the 
event that a media defect renders any one of the other 
seventeen unusable. Each data sector contains approxi- 
mately 568 bytes, including 512 bytes of useful data and 
the remainder being sector address headers, error cor- 
rection, speed tolerance gap fillers, etc 

An index marker 399, generated by motor driver 
circuitry 260 controlling the spindle motor 202, marks 
the location in time for a narrow, approximately 200 
microsecond, 130 byte wide, single servo sector 401 
prerecorded with track centerline information for each 
data track upon one or more data storage surfaces 214a, 
2145 of the disk 214. 

The disk 214 rotates at a substantially constant angu- 
lar velocity, and the time period for each revolution is 
nominally 16.67 milliseconds. The motor driver cir- 
cuitry is illustrated in FIG. 8A and includes an inte- 
grated circuit motor driver, such as type HA 13426, 
provided by Hitachi America, Ltd., 707 W. Algonguin 
Road, Arlington Heights, Ill. 60006, or equivalent. This 
integrated circuit includes a flange which is directly 
mounted to the base casting 12 for the head and disk 
assembly 10. The spindle motor 202 is Y wound and it 
generates three phase commutation signals by Hall ef- 
fect transducers U, V and W responsive to a small per- 
manent magnet in the armature of the motor 202, which 
are used by the integrated circuit to generate the neces- 
sary phases to drive the motor 103, as is conventionally 
known and understood. 

A fourth Hall effect transducer I generates and puts 
out a once per revolution index signal on an index line. 
The microcomputer 381 monitors the index line from 
the motor control 105 and times the interval between 
each index marker 99 to be sure that the disk 96 is rotat- 
ing at proper angular velocity, and it takes the subsys- 
tem 31 out of service in the event that disk rotation is 
determined to be improper. 

Two radially offset, time staggered bursts are pro- 
vided for each concentric data track within the servo 
sector 401. The transducer 320 reads the first burst and 
its amplitude value is sampled and sent to and digitized 
by the microcomputer 381. The transducer 320 then 
reads the second burst and its amplitude value is sam- 
pled and sent to and digitized by the microcomputer 
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381. Differences in the digitized amplitude values are 
used by the microcomputer 382 to calculate centerline 
offset correction values which are stored and combined 
with a digitized phase value and sent to the coil 308 in 
order to maintain the head 320 in centerline alignment 
with each track during track following operations. 

The 612 tracks are divided into five contiguous zones, 
there being four zones of 128 tracks each and one zone 
of 100 tracks each. Track centerline data is acquired and 
stored for the tracks of each zone, and this data is used 
for initial correction whenever the actuator has placed 
the head 320, 322 at a track within the zone. A zone 
timer is set for each zone, and times out after a predeter- 
mined interval, requiring that new centerline informa- 
tion for the zone be obtained before read/write opera- 
tions will be permitted. These architectural features and 
operations of the fine servo loop and track zones are 
explained in further detail in the referenced U.S. Pat. 
Nos. 4,396,959, 4,419,701 and 4,516,177, the disclosures 
of which are hereby incorporated by reference into the 
specification at this location. 

Electronic Return Spring 400 


The aerodynamically released spring biased shipping 
latch 230, already described structurally above, is de- 
flected by airflow generated by rotation of the disk 214. 
This latch 230 includes a member which engages the 
rotary actuator 300, thereby locking the heads 320, 322 
at landing zone positions over the landing zone LZ 
whenever disk rotation is insufficient to generate an air 
bearing effect upon which the heads “fly” (in accor- 
dance with well-known Winchester technology). 

In order to be sure that the actuator 300 returns the 
heads 320, 322 to the landing zone LZ, an electronic 
return spring, symbolized by the switch 400 in FIG. 11 
is provided in the subsystem 5. When power is lost or 
intentionally removed from the subsystem 5, this fact is 
sensed, and the operation of the spindle motor 202 is 
reversed: i.e. it becomes a generator, and the electrical 
energy it generates, due to the kinetic energy stored in 
the rotating disk 214, is switched to the coil 308 of the 
rotary actuator 300. So long as there is disk rotation, the 
electrical energy generated thereby is sufficient to re- 
turn the head to the inner landing zone LZ of the disk 
214 and keep it thre so that the spring-biased latch 230 
reengages the actuator 300 and thereby retains the 
heads 320, 322 at their inner landing zones LZ. The 
dynamics of the latch 230 and the electronic spring 
return 400 are designed so that the heads 320, 322 are 
returned to the landing zones LZ in good time before 
the latch 230 reengages. 

Further details of the aerodynamic shipping latch 98 
are set forth in the referenced co-pending U.S. patent 
application Ser. No. 06/728,674, filed on Apr. 29, 1985, 
for Aerodynamic Latch for Disk File Actuator. 

A significant feature provided by the combination of 
the aerodynamic latch 230 and the electronic return 
spring 400 is that the bias force applied to the actuator 
by a conventional mechanical return spring (and which 
must be continuously overcome during disk file opera- 
tion) is eliminated completely. This means that the actu- 
ator 300 operates with significantly less power con- 
sumption, a consideration to be made when drawing all 
of the power for the subsystem 5 from the accessory 
socket of the personal computer host system. 
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Read/Write Channel 


The overall read/write channel includes a head select 
and preamp circuit 366 which is carried on the flexible 
circuit substrate 362 within the head and disk assembly 
10 and which is described herein in connection with 
FIGS. 13A, 13B, and 13C. The channel also includes 
read/write electronics 409 schematically illustrated in 
FIG. 12A, and a data separator 411. The data separator 
411 encodes and decodes the data bits to and from an 
encoding format, such as 2,7 code, which is used in the 
actual record and playback process on the disk 214. The 
data separator 411 is described further in connection 
with FIG. 19. 


Controller/Interface 


The controller/interface of the control electronics 
for the disk file subsystem 5 includes a programmable 
data sequencer 413 having its own data sequencer ran- 
dom access memory 415, a memory controller 417, an 
input/output data random access memory 421 ad- 
dressed by the memory controller 417 and temporarily 
storing data from the data sequencer 413 from an input- 
/output channel interface 419. 

A BIOS (basic input/output system) read only mem- 
ory 423 is associated with the input/output channel 
interface 419, and it contains basic input output pro- 
gram routines which are accessed and executed directly 
by the host CPU whenever its operating system wishes 
to make use of the subsystem 5. Actually, the BIOS 
memory 423 is not required for operation of the subsys- 
tem 5, and its inclusion is a matter of convenience for 
the user, thereby enabling the subsystem 5 to be plugged 
directly into a personal computer host system without 
requiring the user to add any software driver routines to 
the operating system which are needed in order to use 
the subsystem 5. 

The BIOS memory 423 may also include a collection 
of error and status condition routines which are used by 
the operating system of the host system to determine 
and indicate to the user the status and/or error condi- 
tion of the disk file subsystem 5 from time to time. An 
eight bit tri-state bus driver 425 is interposed in a data 
bus between the BIOS ROM 423 and the input/output 
channel interface 419 and edge connector 365 so that 
the BIOS program routines from the ROM 423 may be 
transferred via the host bus to the host CPU and exe- 
cuted whenever the operating system addresses the 
BIOS memory 423. 


System Buses 


A control bus 431 extends throughout the printed 
circuit card 6. This bus, shown symbolically in FIG. 11 
as a single line, is actually many different lines. Not all 
lines extend to al) elements. For purposes of convention, 
unless a bus line is a data bus or an address bus, it is 
considered to be a control bus line. Thus, the data and 
address buses shown symbolically in FIG. 11 for ease of 
understanding and in more detail in FIGS. 12A, 12B, 
12C, and 12D, define by omission each of the lines 
making up the overall control bus. 

An eight bit undirected data bus 433 enables the mi- 
crocomputer 381 to send digital actuator control values 
to the analog servo chip 385. Digital data passes over 
the bus 433 from the microcomputer 381 to the analog 
servo 385 wherein it is converted to analog values and 
sent to control the position of the rotary actuator 300 
during track seeking and following operations. 
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An eight bit time multiplexed data and address bus 
435 interconnects the microcomputer 381, the program 
memory 383, the data sequencer 413 and the memory 
controller 417, 


A six high order bit (A8-A13) address bus 437 inter- 5 


connects the microcomputer 381 and the program 
memory 383. The low order eight address bits (A0-A7) 
for the program memory 383 are sent by the microcom- 
puter 81 over the data/address bus 435 during address 


time to the memory controller 417 where they are 10 


latched and held in order to be sent over an address bus 
439 to address the program memory 385. 

A five bit address bus 441 and an eight bit data bus 
443 interconnect the data sequencer 413 and its dedi- 
cated small random access memory 415, which stores at 
most only 32 bytes. 

The input/output random access memory 421 is ad- 
dressed via an eleven bit address bus 445 from the mem- 
ory controller 417, while an eight bit data bus 447 con- 


nects the data sequencer 413 and the input/output chan- = 


nel interface 419 with the buffer memory 421. The 
buffer memory 421 provides temporary input/output 
data storage and functions as a sector buffer, holding a 


maximum of two sectors of data which are in the pro- 25 


cess of being stored or retrieved from a data surface 
214a or 214d of the disk 214, in addition to all status and 
control information which passes between the host and 
the subsystem 5. 


A thirteen bit address bus 449 extends between the 30 


edge connector 365, the BIOS ROM 423 and the input- 
/output channel interface 419; and, an eight bit data bus 
connects the BIOS ROM 423 with the interface 419 and 
edge connector 365 via the tri state bus driver 425. 


Data Sequencer 413 35 


The data sequencer 413 is a monolithic large scale 
integrated circuit containing seven internal functional 
blocks, as shown in FIG. 14. These blocks include a 


registers/control logic block 461. This block 461 con- 4p 


tains 32 eight bit internal control registers and associ- 
ated control logic. The registers may be individually 
written to initialize the paramaters that control data 
transfer, and individually read by the microcomputer 


381 in order to obtain status information about se- 45 


quencer command execution. This block 461 includes 
disk address registers for storing cylinder, head and 
sector identification data, status, etc., for the data block 
to be handled. The microcomputer 381 issues com- 


mands to the sequencer 413 by writing to these regis- 59 


ters. 
An error correction code/cyclic redundancy check 
logic block 436 generates and: checks error correction 
code (ECC) or cyclic redundancy check (CRC) bytes 


appended to the data and identification fields respec- 55 


tively of each sector. This block enables use of either a 
standard CCITT 16 polynominal CRC or a program- 
mable ECC. The particular polynomial may be up to 64 
bits long and is determined at initialization time by val- 


ues written into the registers/control block 461. 60 


A serial/paralle] conversion block 465 enables paral- 
lel data from the host to be serialized for the disk. This 
logic is implemented with high speed shift registers 
which effect the necessary format translation between 
parallel and serial data. 6 

A host interface block 467 connects the sequencer to 
the buffer memory 421 via the data bus 447. The DMA 
memory controller 417 provides the addresses in the 
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buffer memory 421 to which the data is to be transferred 
via the address bus 445. 

A disk interface block 469 provides logic to generate 
and receive control signals such as read gate, write gate, 
address mark enable, etc., and it also passes the serial 
data to and from the disk via the data separator 411 and 
the read/write circuits 409 and 407. 

A microprocessor interface 471 enables the mi- 
crocomputer 381 to read and write the internal control 
registers of the block 461 to control operations of the 
sequencer 413 and to monitor its status. 

An interface 473 to the external random access mem- 
ory 415, via the address bus 441 and the data bus 443 
provides access to 32 format parameter registers. These 
format parameter registers specify the size and content 
of the fields within each data sector on the disk. There 
are two registers for each field. One specifies the num- 
ber of bytes in the particular field, and the other speci- 
fies the actual value contained in that field. 

A monolithic integrated circuit, product code OMTI 
PFM 5050 Programmable Data Sequencer, available 
from Scientific Microsystems, Inc., 339 N. Bernardo 
Ave., Mountain View, Calif. 94043, is the presently 
preferred implementation of the data sequencer 413. 

The function of the data sequencer 413 is to monitor 
the serial data stream coming from the data separator 
411 in order to locate the precise sector of a track at 
which data is to be transferred. Once a sector address 
coming in from the data surface is determined by the 
sequencer 413 to correspond with the correct sector 
identification, data read or write operations are then 
carried out. 

In the case of a read operation, the sequencer trans- 
fers the data from the correctly identified disk sector 
(512 bytes) to the sector buffer 421 where it may then be 
passed through the interface to the host. In the case of 
a write operation, the sequence transfers 512 bytes of 
data from the host (stored in the sector buffer 421) 
through the write path and into the data region of the 
properly identified sector in the correct track on the 
selected disk surface 214. 

The sequencer 413 is preprogrammed to carry out 
these transfers on a single sector basis. The microcom- 
puter 381 commands the actuator 300 to servo on track 
while waiting until the sequencer has completed its 
operation before it executes any other commands. Once 
the transfer of a sector of data is completed, a comple- 
tion signal is sent by the sequencer to the microcom- 
puter 381. The microcomputer 381 then checks status 
registers within the sequencer 413 to be sure that no 
errors have occurred. In the case of a data read opera- 
tion, the microcomputer 381 then programs the mem- 
ory controller 417 to transfer the 512 bytes of data from 
the buffer 421 through the interface 419 to the host. The 
microcomputer 381 then continues to servo on track 
while waiting for that transfer to be completed success- 
fully. 


Memory Controller 417 


The memory controller 417 is a low power mono- 
lithic integrated circuit for managing the flow of data 
between the data sequencer 413 and the buffer memory 
421, and between the buffer memory 421 and the inter- 
face 419 and host computer. It controls the transfer of 
512 byte blocks of user data stored on and retrieved 
from the selected data surface 214, and it also controls 
the transfer of command and status bytes to and from 
the microcomputer 381. Fundamentally, the function of 
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the memory controller 417 is to generate addresses 
which are sent to the buffer memory 421 via the address 
bus 445. It also resolves service request contentions 
during multiple block data transfers between the host 
and the subsystem 5, when data blocks are being moved 
through the buffer 421. 

Three channels of the memory controller 417 are 
used by the subsystem 5, and word count registers and 
address registers are provided internally for each of the 
channels. The microcomputer 381 programs the con- 
troller with the address from or to which data is to be 
transferred, the number of bytes to be transferred, and 
the direction of the transfer. With these parameters 
loaded into the controller 417, it then executes the trans- 
fer. 

FIG. 15 sets forth a conceptural diagram of the struc- 
ture of the memory controller 417. Inside the memory 
controller 417 a registers and control logic block 475 
contains the write and read registers for each channel. 
The write registers may be individually written in order 
to initialize the parameters that control data transfer. 
Read registers are available and may be individually 


read by the microcomputer 381 in order to obtain status . 


information about data block movement command exe- 
cution. 

An address generator 477 generates and puts out 
addresses to the buffer memory 421 via the address bus 
445. These addressess locate the data to be transferred 
to the disk via the data sequencer 413 or to the mi- 
crocomputer 381 or to the input/output interface 419. 
In the event of a block transfer the address generator 
477 operates automatically to increment the address 
value to point to the next location in the buffer 421 until 
the entire block of data for the selected sector is trans- 
ferred. 

A data sequencer interface 479 connects the registers 
and control logic block 475 with appropriate control 
lines of the data sequencer 413 via the system control 
bus 431. 

A microprocessor interface 481 enables the mi- 
crocomputer 381 to read status registers and to write 
the control registers in order to monitor and control 
block data transfers. The memory controller 417 also is 
used to demultiplex (latch) program addresses for the 
program memory 383 from the address/data bus 435, 
and these addresses, initiated under the control of the 
microprocessor 381, are applied to the program mem- 
ory via the interface 481 and the address bus 439. 

Finally, an input/output interface 483 enables the 
memory controller 417 to control the operations of the 
input/output channel interface 419. 

A monolithic integrated circuit, product code OMTI 
PFM 5060 Four Channel Memory Controller, available 
from Scientific Microsystems, Inc., 399 N. Bernardo 
Avenue, Mountain View, Calif. 94043 is the present 
preferred implementation of the memory controller 
417. 

The memory controller 417 is preprogrammed to 
control the transfer of information, i.e. both data blocks 
and command and status bytes between the subsystem 5 
and the host system. In this regard, the controller 417 
handles and coordinates the passing of data blocks and 
control and status bytes back and forth across the inter- 
face 419 with the host system. Once a sequence of con- 
trol bytes has been received from the host, (typically six 
successive bytes sent to one of four predetermined logi- 
cal ports to which the subsystem is programmed to 
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respond), these bytes are then transferred to the mi- 
crocomputer 381. 

There is no data path directly between the microcom- 
puter 381 and the buffer memory 421. In order for the 
microcomputer 381 to receive command bytes and to 
send out status bytes to the host via the buffer memory 
421, it is necessary that such bytes pass through the data 
sequencer 413. In order to write a byte to the buffer 
memory 421, the microcomputer 381 sets up the third 
channel of the memory controller 417 for writing to the 
address of the buffer 421 to which the byte is to be 
written. Then, the microcomputer 381 writes the byte 
to a register address within the data sequencer 413, and 
the byte is thereupon automatically transferred to one 
buffer address by coordinated automatic action of the 
sequencer 413 and the controller 417. A similar, but 
2-step procedure is followed to move a byte of data 
from the buffer 421 into the internal random access 
memory of the microcomputer 381. A prefetch is used 
after setting up the controller 417 by the microcom- 
puter 381 to place the first byte into the sequencer 413. 
A fetch is then used to move the byte from the se- 
quencer 413 into the processor's internal random access 
memory. Fetches are then used to transfer all remaining 
bytes of the sequence. 

The memory controller 417 passes data back and 
forth with the host on a byte by byte handshake basis. 
Once a block of data, usually a 512 byte sector amount, 
has been passed successfully, completion of the transfer 
is signalled to the microcomputer 381. 

The host computer normally handles data block 
transfers from and to the subsystem 5 on a direct mem- 
ory access basis wherein after the six command bytes 
have been passed to the subsystem 5, the host central 
processing unit (CPU) relinquishes the data bus and 
data is directly transferred into the active memory of 
the host under the control of a host memory controller. 
Byte-by-byte data transfers are used between the stor- 
age subsystem 5 and the host for command and status 
bytes on a programmed input/output basis, wherein 
such bytes pass through the accumulator register of the 
host. Such transfers may be used for data blocks but 
would take far more time and greatly impair the speed 
advantages normally associated with rigid disk data 
storage devices. 


Input/Output Channel Interface 419 


The input/output channel interface 419 is imple- 
mented as a special purpose low power VLSI mono- 
lithic circuit. This circuit 419 provides all of the cir- 
cuitry necessary for interfacing the controller elements 
413, 417, 381 and related circuitry of the Winchester 
disk subsystem 5 to the input/output channel bus of a 
selected host computer, such as the IBM Personal Com- 
puter TM . The circuit 419 provides a buffered data path 
to the host input/output channel, and it provides ad- 
dress decoding for access to eight host input/output 
address ports, address decoding for access to the exter- 
nal BIOS memory 423 via the buses 449 and 451, and 
circuitry for control of host bus interrupts and DMA 
transfers. 

As seen in FIG. 16, the circuit 419 includes a port 
address decode block 485 which decodes address lines 
A0-A9 from the host I/O channel in order to enable 
selection of eight input/output ports: four write ports 
and four read ports (of which only three are used). Two 
user accessible address select input pins -CNTA and 
-CNTB are provided to change the address range of the 
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host’s input/output ports to enable the use of multiple 
storage subsystems 5 in the same host personal com- 
puter. 

A BIOS memory address decode block 487 decodes 
address lines A13 through A19 from the host I/O chan- 
nel to give a ROM select signal -ROMSEL for enabling 
reading of the external BIOS memory 423. An address 
select input pin -RADR is provided to change the ad- 
dress range of the BIOS memory 423. An input pin 
-ROMDIS is also provided to disable decoding of the 
BIOS address entirely. 

A control logic block 489 contains logic circuitry to 
control the host input/output port register reads and 
writes, data block transfers to and from the host and 
interrupts sent to the host. This block includes two 
internal flip-flops which control whether the host will 
be interrupted at the completion of a command, and also 
whether the transfer of data to the host will be by direct 
memory access through a host memory controller, or 
not. These bits are set by bits DO and D1 of a control 
word written by the host into one of the write ports of 
the control logic block, and control the logic levels on 
an interrupt request line IRQ and a data memory re- 
quest line DRQ extending to the host. A data acknowl- 
edge signal -DACK is received into the control logic 
block 498 from the host to indicate receipt of a data byte 
and thereby signal the readiness of the host to receive 
another data byte. 

A 3:1 Multiplex/Driver block 491 enables one of 
three different host input/output read ports to be read 
on the host input/output channel by the host. These 
ports include an output data buffer 493 (Port 0) which 
latches data on the bus 447 from the buffer memory 421 
and puts out the data to the host through the block 491 
and the data bus 451 on a byte-by-byte handshake basis. 
The multiplex/driver block 491 also selects a hardware 
status register (Port 1) located in the control logic 489 
which thereupon indicates to the host the state of the 
various control signals inside of the input/output circuit 
419, and also a drive type register (Port 2), also within 
the control logic 489, which enables the host computer 
to read the value of four inputs which specify the type 
of disk drive in use. Although a fourth read port (Port 
3) is available, it is not used by the subsystem 5. An 
input data buffer 495 latches data on the bus 451 from 
the host and puts out data to the buffer memory 421 on 
the bus 447 on a byte by byte handshake transfer basis. 


Servo Circuit 385 


A low power monolithic analog and digital inte- 
grated circuit 385 is provided for the analog/digital 
servo circuit. Its internal architecture is depicted in 
FIG. 17. This chip 385 includes the circuitry required to 
carry out digital to analog conversions to provide con- 
trol current to the actuator power drivers 519, 521 for 
track following and seeking operations. The servo cir- 
cuit 385 also performs a peak detection function upon 
the read signal immediately following the index marker 
399 when the head 320, or 322 reads the servo bursts. 
The peak detection function enables the microcomputer 
381 to determine track centerline information from the 
radially offset, time staggered servo bursts. 

The servo functions are carried out by sending an 
analog direct current through the rotor coil 308 of the 
moving actuator assembly 300. The direction (polarity) 
of the current passing through the coil determines the 
direction, whether in or out radially on the disk, of head 
movement. The electromagnetic motion of the head 
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actuator assembly 300 is controlled by the microcom- 
puter 381 which monitors coarse position information 
generated by the optical encoder assembly 100 and by 
the fine position information derived from the single 
servo sector 101 via the read and write channel. 

FIG. 17 diagrams the circuitry of the servo circuit 
385 within its environment of the microcomputer 381, 
optical encoder 100, and rotor coil 308. 

Beginning with the eight bit servo data bus 433 from 
the microcomputer 381, digital data enters an eight bit 
digital to analog converter 501. The digital to analog 
converter is a switch-capacitor design and uses a 10 
MHz clocking signal which is supplied over a line 503. 
The analog output from the DAC 501 is buffered in an 
operational amplifier DAC buffer 505 and then passes 
through an external phase lead filter 507 which provides 
servo loop phase compensation in combination with an 
internal track following servo amplifier 509. A switch- 
ing circuit 513 operating in response to a signal from the 
microcomputer 381 via a servo off control line 517 
enables current to be removed entirely from the rotor 
coil 308 under the control of the microcomputer 381. 

Two external driver amplifiers 519 and 521 are used 
to drive current through the coil 308. A voltage output 
of the amplifier 509 is applied directly to the non-invert- 
ing input of the amplifier 519 and is applied to one end 
of a voltage dividing network comprising resistors hav- 
ing a two to one resistance ratio. A common node of the 
network is connected to the non-inverting input of the 
amplifier 521. The network is also connected at its other 
lower resistance end to a six volt reference voltage, so 
the actual voltage between three and nine volts put out 
to the amplifier 519 is proportioned about the reference 
voltage when it reaches the input of the amplifier 521. 

For example, when a three volt potential is applied to 
the amplifier 519, three volts appears at its output. At 
the same time a four volt potential appears at the input 
and output of the amplifier 521. A one volt difference is 
then present across a ten ohm sense resistor $23. A one 
volt drop across the 10 ohm resistor 523 creates a cur- 
rent flow of 100 milliamps which passes through the 
rotor coil 308 from up to down in FIG. 17, and causes 
it to move the actuator assembly 300. When the voltage 
at the input of the amplifier 519 is e.g. nine volts, only 
eight volts appears across the amplifier 521, causing a 
100 ma current in the opposite direction to flow. 

The voltage drop across the resistor 523 is sensed by 
both amplifiers 519 and 521 at inverting inputs thereof, 
and is used, in combination with the control voltage 
applied to the non-inverting inputs, to control the mag- 
nitude and direction of current passing through the coi! 
308. The driving amplifiers 519, 521 supply a maximum 
of approximately 100 milliamperes to the coil 308, in 
either direction of current flow. 

The two current to voltage converters 525 and 527 in 
the optical encoder subassembly 100 convert the light- 
induced phase currents P1 nd P2 into analog voltage. 
Outputs from these converters 525 and 527 (U1A and 
U1B in FIG. 18) enter the microcomputer 381 analog to 
digital conversion ports and also enter the servo circuit 
385, as shown in both FIGS. 11 and 17. Two compara- 
tors 529, 531 in the circuit 385 monitor the P1 and P2 
voltages and develop digital track crossing signals 
which are returned to the microcomputer via two in- 
verting amplifiers 533, 535, also inside the circuit 385. 
By generating the digital track crossing signals, the 
microcomputer 381 is able to monitor coarse head posi- 
tion during track seeking operations more efficiently 
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than if it had to convert the P1 and P2 signals to digital 
values first. 

A voltage reference element 537 provides a reference 
voltage to appropriate nodes of the circuit elements 
within the chip 385 as shown in FIG. 10. A six volt 
buffer 538 provides a reference six volts to each of the 
DAC buffer 505 and the servo amplifier 509. The six 
volt reference enables the DAC to be varied in its outut 
in a range between three and nine volts over 256 equal 
increments. 

A five volt zener reference from the optical encoder 
assembly 100 passes through a buffer amplifier 539 and 
an external transistor 541 before being put into the refer- 
ence voltage input Vref of the analog to digital circuit 
within the microcomputer 381. When the zener voltage 
from the encoder 100 drifts with temperature changes, 
these small changes are also tracked by the digital to 
analog converter of the microcomputer 381. 

The analog servo chip 385 works primarily with a 
twelve volt power supply, while the microcomputer 
381 works with a five volt power supply. A comparator 
circuit 543 monitors the five volt bus within the servo 
chip 385. If the five volt reference is lost at the chip 385, 
the comparator 543 shuts off the buffer 539, thereby 
preventing the microcomputer 381 from becoming 
damaged because the Vref port is being forced to 
ground potential. It should be noted in this regard that 
all of the outputs of the servo circuit 385 leading di- 
rectly to the microcomputer 381 are open collector or 
are output protected, so that the microcomputer 381 is 
thereby protected against the failure of the chip 385 or 
any of its elements. 

The chip 385 also includes a detector amplifier 545 
which is directly connected to the read/write channel 
in order to receive the sector servo bursts prerecorded 
in the single servo sector 401. The peak voltage levels of 
the read/write channels are translated by the amplifier 
545 into levels more suitable for the analog to digital 
converter input port AD3 of the microcomputer 381, 
driven by the output of the amplifier 545. 


Data Separator 411 


The data separator element 411, preferably formed as 
a monolithic integrated circuit, such as type OMTI 
20527 available from Scientific Microsystems, Inc., 339 
N. Bernardo Avenue, Mountain View, Calif. 94043, or 
equivalent, is depicted in FIG. 19. The data separator 
411 performs three functions. 

First, the data separator 411 determines head position 
relative to the data format. This task is accomplished by 
writing a special pattern onto the data surface 214, com- 
monly referred to as an address mark pattern, which can 
be identified when a read operation is initiated. The 
separator circuit 411 generates and writes the address 
mark pattern while formatting each data track, and it 
identifies the address mark when a read operation is 
begun. 

Second, the data separator 411 defines bit cell bound- 
aries on the disk data surface. This task is accomplished 
by a phase locked oscillator (PLO). The PLO con- 
structs a data clock signal which precisely defines bit 
cell boundaries as they exist in the formatted data track. 
Essentially a flywheel oscillator with inertia to average 
out minute fluctuations in disk speed, the PLO con- 
stantly updates the phase and frequency of the data 
clock signal throughout each data read operation. 

Third, the data separator encodes and decodes nonre- 
turn to zero (NRZ) data to a format more suitable for 
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being recorded on the media as a series of magnetic flux 
transitions, due to constraints peculiar to magnetic re- 
cording phenomena. One suitable format is 2,7 code, 
and the data separator 411 handles the code conversion. 

The monolithic data separator circuit 411 as shown in 
FIG. 19 includes a sync field qualifier circuit 551. This 
circuit 551 inspects the frequency of incoming pulses 
from the read electronics 409, The output of the circuit 
551 is a logical one or zero, depending upon the fre- 
quency of the incoming pulses. For example, if the 
pulses are separated by less than 204 nanoseconds or 
more than 602 nanoseconds, the output will be low. If 
the pulses are separated by greater than 300 nanosec- 
onds and less than 492 nanoseconds, the output wil be 
high, indicative that a sync field is validly present in the 
raw data stream. Only if the sync field is valid will the 
PLO be permitted to lock onto incoming data. 

This circuit 551 is also used to reset a read sequence. 
A search for the address mark cannot be initiated until 
the sync field is valid for eight bytes of data. Only then 
may a read sequence progress if the sync field falls to 
zero. If it does before the consecutive eight bytes are 
received, the read sequence is automatically reset. This 
mechanism protects against write splices. For examle, 
data having a hexadecimal value of 33 encodes to one 
pulse every 800 nanoseconds, which will force sync 
field low. A field of hex 33 is written on either side of a 
five byte field in the format where write splices may 
occur. This forces the read sequence to be reset upon 
entering the write splice and coming out of it. This is 
important, because over time, write splices could form 
into any pattern of data including hex FF data and an 
address mark. However, by making the correct se- 
quence greater than five bytes and forcing a reset of the 
read sequence on either side of the write splice, a false 
address mark cannot be generated. 

A read control circuit 553 provides a mechanism to 
discover where the data transducer head 320, 322 is 
located relative to the data format of a track being read, 
and to lock the PLO to the disk data. The control cir- 
cuit 553 includes a four bit asynchronous counter, three 
state holding flip flops and various decoding logic. A 
Lock to Data (LTD) signal forces the PLO to phase 
lock to the read raw (RD RAW) pulses coming from 
the read channel 409. A bit sync (BITSY) signal enables 
the decoder to block incoming encoded bits for correct 
decoding. A search for address mark (SAM) signal 
enables another state machine 555 to determine whether 
an address mark is present on the disk at the precise 
moment, or not. The appropriate action is then taken by 
the SAM circuit 555. 

The phase lock oscillator 557 defines the bit cell 
boundaries as they exist on the formatted disk during a 
read operation. The PLO 557 comprises a phase com- 
parator, a filter and a voltage controlled oscillator 
(VCO). The phase comparator compares the phase of 
the encoded data read from the data surface 97 with the 
VCO signal. It then supplies a current via an I_SR- 
C_SNK pin whose duty cycle is proportional to the 
phase difference between the two signals. The filter 
requires external passive components to provide phase 
compensation to the phase lock loop, to attenuate the 
high frequency components of the I_SRC_SNK sig- 
nal, and to convert the current into voltage. The VCO 
is a voltage to frequency converter which provides the 
decode machine with a bit rate clock of the same phase 
as raw data. The frequency is determined by the filtered 
I_SRC_SNK signal. 
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A decode machine 559 and a bit sync logic block 561, 
taken together, are the heart of the data separator. They 
take in encoded data, such as in 2,7 code format, or 
another suitable format, from the read channel 409, 
decode such data and put it out as NRZ data in phase 
lock with the read clock RD_CLK signal. There are 
two code bits for every one NRZ data bit, and the code 
bits must be blocked together correctly before they may 
be decoded. The bit sync logic block 561 determines 
correct blocking of encoded bits in response to a valid 
bit sync signal (BITSY) as generated by the read con- 
trol circuit 553. 

A write address mark state machine 563 generates the 
write address mark signal (WAM) at a specific time 
related to the address mark enable signal AM_ENA- 
BLE. The WAM signal is used to invert two adjacent 
code bits. This alters a correctly encoded byte of data 
into a unique pattern which is not generated by the 
encode logic because of the encoding rules of the partic- 
ular code employed. This pattern serves as the address 
mark. 

An encode machine 565 converts NRZ data from the 
data sequencer 413 into encoded data in accordance 
with the selected encoding scheme, whether it be 2,7 
code or some other satisfactory code. Encoding opera- 
tions are carried out whenever the write gate line 
(WRT_GATE) is enabled. When the write address 
mark signal WAM is asserted, code bits are inverted. 
Code bits are synchronized to the reference clock signal 
REF_CLOCK provided from the data sequencer 413. 

A clock generation and multiplexing circuit 567 con- 
tains the circuitry required to divide the reference clock 
signal by two in order to generate a write reference 
clock WREFCLK signal. This signal is required for the 
encoding operation of the machine 565. The multiplexer 
in the circuit 567 steers one of two inputs to a read 
reference clock output RD_REF_CLK which goes to 
the data sequencer 413. During a read operation, the 
read clock signal RD..CLK (which is synchronous 
with the NRZ data put out by the bit sync logic block 
561) is passed to the data sequencer 413 to synchronize 
it with the NRZ data stream. 

A test logic block 569 enables special tests to be car- 
ried out on the data separator chip 411. Such tests in- 
clude holding the LTD line high in order to measure 
loop parameters of the PLO 557. Also, data may be 
delayed from the disk with respect to the bit cell in 
order to perform window margin testing. And the time 
lag between two internal signals may be changed in 
order to optimize the setup time on the phase compar- 
ing flip-flop. 


Disk Format 


A format arrangement for the subsystem 5 is depicted 
in FIG. 20. Therein, eighteen identical sectors are pro- 
vided following the index mark 399 and the post-index 
gap which contains the wedge servo bursts and a toler- 
ance region for index drift. An ID preamble contains 12 
bytes of hex FF data. Its purpose is to synchronize the 
PLO 557 before the data sequencer 413 reads the ID 
DATA FIELD. The hex FF pattern is used because it 
provides the highest frequency read pulses of any single 
byte repeating pattern. Its length allows for two bytes 
of PLO sync detection before locking the PLO, five 
bytes of PLO sync time, one byte of phase set time and 
four bytes for margin. 

An ID SYNC BYTE is the single address mark byte 
for each sector. It is made unique by violating the en- 
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coding rules otherwise carried out by the encoding 
machine 565. The resultant unique pattern is known to, 
read and check by the data sequencer 413 in order to 
validate the particular sector ID. 

An ID MARKER BYTE is a byte of hex FE data, 
chosen only to be different from the DATA MARKER 
BYTE. The data sequencer 413 uses this byte to deter- 
mine that a sector ID data field is about to be read. 

An ID DATA FIELD includes four bytes holding 
the sector address in the form of cylinder high, cylinder 
low, head and sector. 

An ID ECC field of two bytes of CRC information 
are used by the sequencer 413 to check the validity of 
the sector address. 

A three byte field ID POSTAMBLE of hex 33 data is 
provided to guarantee a stable read clock from the PLO 
during the time that the last bits of the ID ECC field are 
read, decoded by the decoder 559 and passed to the 
sequencer 413. 

A DATA PREAMBLE field duplicates the ID Pre- 
amble field, and its purpose is to synchronize the PLO 
before reading the data field. 

A DATA SYNC BYTE serves the same purpose for 
the data field as was served by the ID DATA SYNC 
BYTE for the ID data field. 

DATA MARKER BYTE is a byte of hex F8, used 
by the data sequencer 113 to determine that a data field 
is about to be read. 

DATA FIELD. This field is for storing a block of 
512 bytes of user data. It is initially recorded with hex 
33 data during a track format operation. 

DATA ECC is a six byte field for data error correc- 
tion code. 

DATA POSTAMBLE is a three byte field of hex 33 
data and guarantees a stable read clock from the PLO 
during the time that the last bits of ECC are being read, 
decoded and passed to the sequencer 413. 

INTERSECTOR GAP is a ten byte field of hex 33 
data containing three functionally separate sections. A 
three byte write-update field allows for the data pream- 
ble and data field to move down the track by up to three 
bytes between a format operation and a write update 
operation. This shift is accounted for by the data format 
encode and decode delays, a one byte sequencer delay 
and a number of single bit resynchronization delays. A 
five byte speed tolerance gap allows for a plus and 
minus point four percent (0.4%) speed variation of the 
spindle motor 202 to be accomodated between track 
format operations and write update operations (a 0.8% 
maximum difference). Finally, a two byte pad guaran- 
tees at least two bytes of hex 33 data before the ID 
Preamble of the next sector. This forces the PLO sync 
field detector to restart the address mark search se- 
quence even if it had falsely detected some PLO sync 
data from write splices in the speed tolerance field. 

PREINDEX GAP is a 43 byte field of hex 33 data at 
nominal spindle motor speed. Its purpose is to allow for 
motor speed variations during track formatting. An 
overspeed of up to 0.4% may be accomodated. 


Control Software 


The microcomputer 381 operates essentially in an 
interrupt driven mode. There are several inputs to the 
microcomputer 381 for setting its internal interrupt 
request flags. All interrupts are software maskable, ex- 
cept a nonmaskable interrupt line which may be oper- 
ated by the host operating system (write to Port 1), in 
order to reset the subsystem 5 should it become lost 
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(hung up) during command execution. The host reset 
operation is flagged through the BAR NMI port, pin 25. 
All other host commands are initiated by an interrupt 
which is flagged through bit position 3 of Port C, (BAR 
INT2, pin 20), which may be software masked if some 
task having a higher priority is in a critical phase of 
execution. 

There are three main phases of software execution: 
Initialization, Main Loop, and Command Execution. 
The initialization phase, at power on (or upon an NMI 
host RESET command) resets and/or preloads all of 
the control registers with initial or default values re- 
quired for proper operation of the data sequencer 413, 
the memory controller 417 and the head and disk assem- 
bly servo system. The operating parameter registers 
within the microcomputer 381 are also cleared and set 
with initial or default parameters. Once the subsystem 5 
is set up, the microcomputer 381 seeks to track zero and 
enters the main Joop. 

The main loop is essentially an idle mode for main- 
taining the status quo. A track following servo value 
generated by the microcomputer 381 is latched into and 
converted to an analog voltage by the digital to analog 
converter 501 and is converted to a current which 
passes through the rotor coil 308 to keep the heads 320, 
322 centered on track. A phase byte selects which 
phase, whether P1, P2, BAR P1, or BAR P2, should be 
used for servoing on-track. (P1 and P2, being in quadra- 
ture, logically define four adjacent track locations and 
boundaries). In the main loop, the microcomputer 381 
creates a tight on-track servo loop about the selected 
phase signal. The selected phase is digitized and read, 
and the servo loop is updated, approximately every 90 
microseconds. The analog to digital conversion process 
requires approximately 48 microseconds, and the digital 
processing and update requires the rest of the 90 micro- 
seconds, the time duration for main loop execution. This 
updating of the track following servo continues repeat- 
edly until an interrupt occurs. It is expected that ap- 
proximately 95 percent of the useful life of the subsys- 
tem 31 will be spent in executing the main loop. 

There are three main interrupts which cause the mi- 
crocomputer 381 to exit the main loop. The first inter- 
rupt is an Index Interrupt, which occurs once each 
revolution of the disk 214. The prerecorded A and B 
bursts in the servo wedge 401 are read sequentially and 
peak amplitude sampled through the analog to digital 
converter within the microcomputer 381. The two am- 
plitude values are compared, and any difference value is 
used in a computation to provide an error correction 
value which is combined with the digitized selected 
phase value from the optical encoder to derive the cor- 
rection value sent to the digital to analog converter 501. 
At the completion of the servo routine at Index, the 
microcomputer 381 returns to the main loop. 

Another interrupt is a RESET operation from the 
host which is generated by the host’s operating system 
in the event that the subsystem 5 fails to respond to 
other host commands. The Reset operation creates a 
hardware interrupt in the subsystem 5 and forces it to 
reinitialize. In this manner, if the microcomputer 381 
gets out of sequence in executing commands, error 
recovery, if possible, will be accomplished. 

A third interrupt is a SELECT Interrupt which is 
generated by the host computer when it sends a Host 
Command to the subsystem 5. Each command received 
by the microcomputer 381 is compared with a table of 
valid commands. When a matchup occurs, the table 
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provides an addres for a command execution routine in 
the program memory 383 which corresponds to the 
particular valid command received from the host. If no 
matchup occurs, the command is rejected as invalid. 
Ordinarily, when a command is received, the mi- 
crocomputer 381 is interrupted, and jumps to, and be- 
gins executing the command routine for the particular 
command. At command completion, the microcom- 
puter 381 returns to the main loop. 

A Timer Interrupt occurs every 150 microseconds 
during seek operations which are carried out in re- 
sponse to a select interrupt which requires a seek opera- 
tion. 

There are a number of Host Commands which may 
be given to the subsystem 5. The following Host Com- 
mands are representative of the types of commands 
likely to be sent by a host to the subsystem 5 in order to 
carry out useful data storage and retrieval operations. 

TEST DRIVE READY which is a check to see if the 
subsystem 5 is ready to receive another command, or to 
see if it is e.g. seeking or otherwise unavailable. The 
subsystem 5 puts out an error message to the host in the 
event that it is not ready. 

REQUEST SENSE STATUS which is invoked to 
send four bytes of a sense block which characterizes 
current status of the subsystem 5. This command re- 
quires the subsystem 5 to be set up to transfer the four 
bytes; the bytes are placed in the buffer 421, and then 
they are sent to the host via the interface 419. The mi- 
crocomputer 381 waits until the host signals receipt as a 
command completion. Any error conditions are sent to 
the host in response to this command. 

READ ERROR LENGTH. This command sends 
the host a one byte burst length of the last ECC error. 
It requires a setup for a one byte transfer via the buffer. 

INITIALIZE DRIVE CHARACTERISTICS. This 
command enables the host to initialize the characteris- 
tics of the subsystem 5. The memory controller 417 is 
set up to transfer eight bytes of data from the host 
through the buffer 421 and into the internal RAM of the 
microcomputer 381. This information includes the max- 
imum number of cylinders (track locations) and heads. 
Also, the maximum ECC data burst length is stored. 

FORMAT TRACK. This command enables the host 
to format a single track. The track address is checked to 
be sure it is legal; the sequencer 413 is set up for format- 
ting; the format track command is sent to the sequencer; 
and a “bump detect” function is monitored throughout 
the formatting operation. (The Bump Detect Routine is 
used to detect whether any physical impulse has jarred 
the subsystem 5, causing the head to move off of track 
centerline alignment. This routine calls for monitoring 
the selected servo phase put out by the optical encoder 
100 as closely as possible (75 microsecond loop) during 
the format operation. If a bump is detected, the one 
track format operation is automatically repeated.) 

FORMAT DRIVE. This command is invoked by the 
host in order to format all of the host-accessible storage 
capacity of the subsystem 5. It includes carrying out the 
FORMAT TRACK command for all of the data tracks, 
beginning with the track specified in the command and 
continuing through track 611. 

READ DATA. This command enables the hast to 
receive the data from one or more specified number of 
sectors. A legal starting address is checked. Then, the 
actuator 300 is commanded to move the head trans- 
ducer from its present track location to the target or 
destination track. After the seek, the memory controller 
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417 and the data sequencer 413 are set up for operations 
at the destination track, and a command byte is sent to 
the sequencer to start data transfer operations. The 
microcomputer 381 waits until the sequencer 413 fin- 
ishes reading the proper sector at the destination track. 
Errors are checked for, and the microcomputer 381 
waits until the host memory channel is ready to receive 
the data commanded. The transfer process to the host is 
then initialized in the memory controller 417 and the 
transfer to the host is carried out. 

If there are additional sectors to be transferred to the 
host, the next address is generated and loaded into the 
sequencer, and the sequencer is then restarted. This 
process goes on until all of the data is transferred to the 
host. If the operation requires access to sectors in adja- 
cent tracks, automatic single track stepping (and head 
switching) is commanded at the appropriate time by the 
microcomputer 381. When all sectors have been trans- 
ferred, the command is completed and the microcom- 
puter signals command completion to the host. 

WRITE DATA. This command follows the same 
progression of steps as are followed by the READ 
command, with the exception that data is received from 
the host over the interface 419 and via the buffer mem- 
ory 421. The microcomputer 381 moves the selected 
head to the correct track location. The first block of 
data is transferred from the host to the sector buffer 421. 
The sequencer 413 begins reading sector headers. When 
the right sector is located, the sequencer transfers data 
from the buffer 421 through the write channel, so that it 
is recorded in proper time and position in the data area 
of the sector. This process is carried out for each sector, 
until the command is completed. During the writing 
process, the microcomputer 381 while waiting for a 
command completion signal constantly performs the 
bump detect routine, to be sure that writing is inhibited 
in the event that a bump is detected. If a bump is de- 
tected, the sector is rewritten after the head and disk 
assembly has stabilized. 

Other Commands. There are a number of utility com- 
mands (such as a SEEK which is not a part of a READ 
or WRITE command) which may be provided to carry 
out certain tests and operations desired by the host. 
These commands are a matter of design choice and are 
routinely understood in the art and are not essential for 
successful operation of the subsystem 5. For this reason, 
they are not described herein. 


Command Structure and Addressing 


Every command which is sent to the subsystem 5 by 
the host is six bytes long. The first byte is a command 
code to identify the type of command, and the succeed- 
ing bytes provide the necessary parameters to carry out 
the command. Then, typically a block of sector data 
(512 bytes) is sent to or from the subsystem depending 
whether the command was a write or a read command. 
Other commands are the Initialize Drive Characteris- 
tics command which transfers eight bytes of data from 
the host to the subsystem 5, the Request Sense Status 
command which transfers four status bytes from the 
subsystem 5 to the host, and the Read Error Length 
command which transfers one byte from the subsystem 
to the host. 

After the subsystem 5 has completed each command, 
the microcomputer 381 sends out a one byte command 
completion signal to the host, of which only two bit 
positions are used. The first bit indicates drive number 
(whether drive number zero or one) and the other bit 
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indicates whether or not an error was detected during 
command completion within the subsystem 5. 

All communication between the subsystem 5 and the 
host system is carried out across eight ports: four input 
ports and four output ports of the host system. The 
ports are paired together, so that for example port 0 
which is a single logical address is one port in its input 
mode and in its output mode is another port. All data 
transfer is via port 0. All hardware status information is 
transferred from the subsystem 31 to the host system via 
port 1. The host reads the status port during data ex- 
changes so that it may synchronize its operations with 
the state of the subsystem 5. For example, it looks at the 
request bit of port 1 before sending each command byte. 

Port 1 has very different meanings in read and write 
modes. In the read mode port 1 enables the host to read 
the hardware status lines of the subsystem 5. The lower 
four status bits of port 1 are used to carry out a hand- 
shake control for each byte of data transferred between 
the host and the interface 419 of subsystem 5. The busy 
bit (3) is set by the subsystem 5 whenever it is in the 
process of executing a host command. For example, the 
busy bit is set by the subsystem 5 when the host selects 
it for an operation (a write to port 2) and remains set 
until the command completion byte is sent to the host 
via port 0 at the completion of execution of a host com- 
mand, whereupon the busy bit of port 1 is cleared. 

A control/data bit (2) indicates the status of the data 
bytes being transferred via port 0, whether control 
bytes or data bytes. An input/output bit (1) indicates 
whether the data at port 0 is output from the host or 
input to the host from the subsystem 5. (Output, if user 
data, corresponds to a Write command; Input, if user 
data, corresponds to a Read Command). A request bit 
(0) enables a byte by byte transfer handshake control. 
The setting and clearing of this bit coordinates the 
transfer of each byte between the host and the interface 
419, during non-DMA data transfer operations as when 
command bytes are being sent. 

A write operation to port 1 by the host generates a 
reset signal which results in a non-maskable interrupt of 
the microcomputer and a reinitialization of the subsys- 
tem 5 under host operating system control. 

Port 2 is used by the host to read a drive type byte 
which may be used to indicate to the host which type of 
peripheral is attached to the host system. This byte may 
be polled, for example, by the host to determined stor- 
age capacity size, in the event that the storage capacity 
of the subsystem 5 is increased e.g. to 20 megabytes by 
the addition of another data storage disk 215, as shown 
in FIG. 11. 

A write to port 2 generates a controller select pulse 
which sets a flip-flop within the Input/Output Interface 
419 which has an output line -BUSY. This line inter- 
rupts the microcomputer 381 when a command from 
the host has been received at the interface 419. To start 
a command sequence, the host writes to port 2, causing 
the -BUSY line to become true. This event is detected 
by the microcomputer 381 and it leaves the main rou- 
tine and begins a command execution routine. At the 
same time, the host monitors the subsystem hardware 
status port 1. As soon as the host sees the busy signal 
being asserted (true), the command/data (C/D) line 
being asserted (true), the input/output line not being 
asserted (not true), and the request line being asserted 
(true), it knows that the subsystem 5 is ready to receive 
the first command byte. The first byte is then written to 
port 0 by the host and is temporarily stored the input 
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data buffer 495 of the I/O interface 419. An ACK signal 
is then sent to the memory controller 417, telling it that 
the first command byte is in the buffer 495. The memory 
controller 417, drops the request signal, generates a 
Memory Enable signal, and the byte is then transferred 
to the buffer 421 and stored therein at an address com- 
manded by the memory controller 417. The memory 
controller than raises the request signal again, thereby 
signalling the host to send the next command byte. This 
procedure is followed until all six command bytes are 
stored in the buffer 421. They then go to the microcom- 
puter 381 for execution, and at the completion of execu- 
tion a command completion byte is latched into the 
output data buffer 493 read by the host at port 0. 

Port 3, the fourth port, is not used as a read port. It is 
used as a write port by the host to enable/disable DMA 
operations and interrupt sent to the host from the sub- 
system 5. Thus, the host may write to port 3 before 
every command so that it may specify to the subsystem 
5 whether the host expects to be interrupted at the end 
of the command, and whether the command to be exe- 
cuted will use block transfers by DMA if it is e.g. a read 
or write command. 


EXAMPLE 1 


The subsystem 5 is in the main loop, servoing on 
track. The host operating system will write to port 2 
which will create a signal -BUSY which is an interrupt 
to the microcomputer 381 and which causes it to exit 
the main loop. The microcomputer 381 enters an inter- 
rupt service subroutine which will cause the memory 
controller 417 to raise the Request bit in order to obtain 
the first command byte via port 0. When the host writes 
the command byte to port 0, an acknowledge signal is 
sent to the memory controller 417 causing it to lower 
the Request signal and temporarily store the byte in the 
buffer 421. The Request bit is again raised, and the next 
byte is received across the interface 419 in the same 
manner and stored in the buffer 421. The handshake via 
the Request bit of the status port 1 continues until all six 
bytes of the host command have been received and 
stored in the buffer memory. The memory controller 
417 is preprogrammed so as to expect to handle recep- 
tion of the six command bytes. Completion of reception 
of the six command bytes is signalled to the microcom- 
puter 381, whereupon it transfers the six bytes from the 
buffer 381 to its own registers via the data sequencer 
413 as already explained and decodes the command by 
comparison with a list of valid command in a look up 
table stored in the program memory 383. Once the 
command is decoded, the microcomputer 381 jumps to 
the routine necessary to carry out that command. In the 
event that the command received does not correspond 
to any of the valid commands listed in the lookup table, 
an invalid command error message is returned to the 
host. At the completion of execution of a command, a 
command completion acknowledge signal is returned to 
the host. The occurrence of any error known to the 
subsystem § occurring during command execution is 
also signalled to the host, and it can then test the status 
of the subsystem in an attempt to learn what type of 
error occurred. 


EXAMPLE 2 
One critical operating situation arises in the situation 
where the first host command received by the system is 


a Seek command, and the very next command received 
is a Test Drive Ready command. During the fastest 
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portion of the seek, the microcomputer 381 has to re- 
ceive, process and complete the command by returning 
a Status byte to the host, while simultaneously monitor- 
ing track to track crossings of the head and actuator 
structure, al] in such a manner that the actuator does not 
become lost. In order to carry out this worst case oper- 
ating scenario, the processing task for processing the 
incoming command from the host is divided up into 
several segments. The microcomputer 381 accom- 
plishes the segments in the very little time available 
between the track boundary sensing and calculations 
which are required to maintain control over head posi- 
tion during the seek. The microcomputer 381 in effect 
begins to process the incoming command, and goes as 
far as it can with the process until it is time to leave it 
and to sense the track crossing and increment (decre- 
ment) the track counter. Then, the microcomputer 381 
returns to the task of processing the incoming command 
until the next time interval elapses for monitoring track 
crossing. 

The seeking algorithm employed in the subsystem 5 is 
interrupt driven by a timer. It is a position algorithm, 
rather than a velocity or acceleration algorithm. Every 
150 microseconds during track seeking, the microcom- 
puter 381 is interrupted and carries out a Seek routine. 
It looks at the digital P1-P2 phases to see how far the 
actuator has progressed in that fixed time interval, i.e. 
how many tracks have been passed over by the head 
during that time; and, it updates the tracks traversed 
register and checks actual location of the transducer 
against a look up table containing a power acceleration 
curve which contains expected position data. Finally, it 
adjusts the acceleration of the actuator 100 to bring 
head position into correspondence with expected head 
position stored in the look up table. 

For example, if the head 320, 322 has crossed 20 
tracks by the end of the interval, and the look up table 
says the head should have crossed 25 tracks by that 
time, the acceleration (current through coil 91) is in- 
creased to catch up. If the actuator 100 is four tracks off 
of the target track location stored in the look up table, 
the actuator 100 will receive a maximum torque value 
(maximum current will be passed through the coil 308). 
At the completion of the Seek command, the actuator 
300 will be permitted to settle at the target track. 

Since the optical encoder 100 is capable of separately 
identifying each one of four tracks, the timer interval 
must be selected in relation to the maximum head actua- 
tor seek velocity, so that the head will not move more 
than three tracks during the time interval. If it were to 
move four tracks, a hopeless ambiguity would arise, 
making it impossible for the microprocessor to update 
the track count register and to calculate the current 
correction value. 

Here follows an object code listing of a control pro- 
gram which actually carries out the operations de- 
scribed hereinabove in a subsystem constructed in ac- 
cordance with the presently preferred subsystem 5 as 
described. In this listing, in Tektronics format, each 
horizontal line represents a separate record. The slash 
mark is the beginning of each record. The first two 
hexadecimal bytes correspond to the address of the first 
byte of the record. The third byte corresponds to the 
hexadecimal count number of data bytes in the record. 
The fourth byte comprises an eight bit sum of four bit 
hexadecimal values for the six digits which make up the 
address and byte count. The last byte of the record is an 
eight bit check sum of the four bit hexadecimal digits 
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comprising the program data bytes. All bytes between 
the fourth byte and the last byte of each record are 
program data bytes. 


/9000030354%770017 

4000403075412010D 

/OOOBOXLOC1OLLAAZIIA 

/OOLOOSOES49CFFOL0441 

/0018040D6901 4E622A 
/00201E11B04CE3404D 1 SAQAAG2434F 707972696768742031399383520504C 5553204434 
/003E1E2065762E20436F 72702E484454EB81 6641908688071 1 2EFSBFFO407FFS40GFF 83 
/005C 1E2004F FFFAA40940 1 540800484454 9F FF4401 1DS8807 1 LPEFEBFFAAGZEEFFOIB1 
/007A1E20007 10105BA63006400806401 54697004DD269004DD34640200697F 4004690818 
/00981E204DD169084DD0 1 O68F FO4SFFFF7 1 0O2003402F F 2403FF4BFC31715E0471 72047E 
/00361E201 41006701 ES3FF341300488334C0F F 48937 1 020840E61440A71S0S02F 76427 
/OQODS5 1E204A084F 7E6406FF 3447007 OSEP DFFE970063646363656548439006407E7AAS0ES 
/O0F21E2017134095116A02015857014822414702C b64CCA2S60CACEEBACE 260C HESEIOSSF 
/OLIOLELI4F6C5SBO2C 2AA626903S8024F 614844 0004F FFF E6409F 32641904440 S0040EF SB 
/QL2ZEOSL40B 4FA72F 
/01311E£140001040506070B0A0BOCODOEOFEOESE 4E SEGE7ESE PEAEBECEDEEEFFOFIF2DS 
/O14F 1E23F SF 4F 51F037F0452042606D503D20397055406A60F SBOS4A03BCO3A303B244 
/O1SDLE2Z302AE02F BOZDDOSB206390AAC OADBO9F DOPAEORBEDOSF40A4SFOBCZOAAIOBIBAS 
/0182 1E230AEBO?7DDOBES08750934466FF7 18008401 10C6409F 7400701401 1O2B8700E4S5 
/O1LAILEZIA2ZFF6966038542B03346EFFS567205472FF 4380071 SEQOS436FF01693D01 6864 
/01C71E231A48254835483907033D016707SF3D0A073F3B01LSAS6SB171 7020345201 141E 
/01E$1E2391010166488570E94828 1 2307 DF 669201 $05043472FFSD67346EFF 709830 5B 
{02031107 700F A2FF 644A08BBO4F FFE S4D000402)D1 SE 1 

/02141E16016707201 7025A0307FD634C 4400004 0000CS46CFF71 80004021 0CES46603FD 
/O2321E1LS64E1D3471 FF 3546720347 SFF2SS46FF2CSF2C 2248204831 46314891 /OFVESFAATA 
“O2501E163B42088026C0558586C011 4 7EOF SFO031 41 90F 58021 4020F SDEEESED6419085E 
/Q26E1E25707912804829707D 1 2806409F 3641 90405039F B44050040EF OBBB7OSFESFF4C 
/028C1E25693340CB0B7 1 800F 3466FF 4021 0C3483FF 488367107041 14000B74ED44103D 
/O2A4A041A0648938B31 
/QOR2AELE2ZT407BOCES407 BOC O4OGFEGAFF 40CEQO2EA00S0CE02S406F FBGGAO4FFEI30S548C. 
/02CC 1LE29F $013940000693340C BOB2428804400080A3A32749FFFES4O0006973140CB0B1E 
/O2EALE292428804 40008 2A2ZAG0FA4SFD0927 4FFF7BS407E0C403D1 35 406FES400004 44 
40308 1E1A002069007093327 4F FFAGQ3SF S406FF 67 0OBBE931 S4F S01 407B0CSS02010847 
/03261E1A690854F 501 4403004000007 1BO0S3S4¢EFF 556720347 2FF40210C469ED707937 
/93441E1A128040020F88407B0C44000040000C7 18000349UFF4FE2407B0C 440700400E 
/OB621ELAEFOBOTEF7O79 1 28040020F S4A4SFF7 18007401 1L0CO1LA4634601A5634701 A640 
/OJBOLELAG34901LABS7OCEPOBESE7TSOBAL SOLAZIBO1IAGLIISAS2Z0174EF SSCHOQOSEASSIBA 
/OSTELEQSSAFF4SB973B840700C44FF0140C SOB S40000703E7AFFOIEFSODSOBSOOZSOFESS4 
/OSBCLE2ZS4O07BOCS4FFO1L40CSOB703SF7AFF 69EDSODE0B 40020F BB71 SEBOSO2A0NC SOSFBO 
/OSDALE2Z9OF 40ED0C717604402C 1240F 41 240ES50D1 4600470 LEPDFFES09F ET BSAS41 95D 
/OSF81E29014843006407F 734000369731 40E40B46706707 F20B0636D40680E3E1 164459716 
/OSIECIELAOISEOCSSO9FESO7E4FC 16901 54F 5014075087181 107139970071 760A673 1 EA2D 
/98341E1A02401607 G06B0ECFS7004E04E4490 LC 76409F ES0764FES62039908 LSFDDEBSE 
/OSSSLELAGOZAQCSO9FFOF 40DBOS40070EBSFSECOCOBO4OL 7L3BABSAGIO7T4SOELLYSYG409F ESS 
£9470101940171370869228097F 06407FFAQAAS2407B0C OSSBFESCOZ4EB7 71760453445 
/O43D 1 E2BA00CO703EBSFF 40AE0CD3406705F 8550208 4E2E 1 5020840A7 1 SOS02F 7084047 
/044B1E287414405708400014703F 3DFFA7S40000703ESBFF 74EFBES076C1CE409F OF SB 
/04C91E28402C 124FBE40380540741414F BFF 4085053446009 703EBSFF4A0491 235ASCO4C 
/04E7 LE2BC6406705F S4E224049 1201 AS 74BBASCESIOS7TOSF3ASELBSO7 4141 4FFFF408588 
/05051E1905402C 1240741440001 4B80502EF 40380501 4C5858C4490059 SBE9FF4S34F32 
/OS2G1E1P9O14SC 55580 1 C&S69FF 5958690063501 4F 6FF 40H SOSBE0S02FD34200340AC114C 
405411E196700D015020240E01 140590540E01 1405905B84905S47E00205SB0SSB0301E4 
/OSSF 1D27505858014F 6356B87 16700716A14716901 40F 20834BSFF4883691470612C 
/097C1324469314000074EDBIE84400003438FF48975A54893400014409FOFEE2D 

/OSPT LELZSAO02A0C AOPFOF7 1 9BOO4S4F FOL 40720840900867336A1 7401607 40680EC 54024 
SOSBSIEZ42EO7C1LFOS SOS0840020F 703F 7AFFE6PTEDIOD60B3081C440020F BESOFEODS44B 
/OSDI1E24780C017B1 6046378 4FCC402A0C 4097F OF 4403027 566ES 4405024072084 09702F 
/OSF11E240B869336A097401 607404B0EC S402E07C 1FOSS030840020F 703F7AFFSTEDSO4F 
/OL0F 1E24D60B3081C 440020F B840FE0D54780C017B1604637B4FCC402A0C40SF OF7 167 
/062D1E24980044FF01407208409008693346A1 9401 607 40680EC5402E07C1F 0390810127 


/064B 1E24B840FE0D54780C 4FES402A0C 409F OF 44F FOL A0720B40900BS4000069EF 4059 © 
40669021 7DS0B1E 
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/066B1E2640020F 693 16A024016073081CC 40680EB8402E07B87 1B 1 O0EATOBF7EFF7442 
/06691E261604703E7 SFFS9EF40D460B 404680ECC402E070849316A02401607F001791668 
/O6A7 LE2b04637B 40F E0DS4780C 4FBP402A0C 409F OF 4403027 966E6 440502407 2084040 
/Q6CSIEZ6F7OOB34000069EF 40D 408 20020F 6931 6A0A401 6079081 CCSOGBOCEBE“O2ZEO72C 
/OSESLIE2S6BS87 1 BLOOCEA7OSF7EFF7414604703E7 GFF S69EF SODS60B406B0ECCSIO02EDTCBSIPAL 
/07011E17316A0A401607F0017B1404637B40FEQ0D5S4780C4FB9703F 7AFF40E 400342164 
/O71F1E26804B010139707927800ASS3B463EDEBEESOUFESG7OOSESSZOLETOFFOBSGYVOOSES1 
/O73DIESSIES7704ES3745A044E2E7 2 SAOBSEQFS45ALODESTO4ADIS7TOLZ4ESS74ASAOSDLGZ 
/O75SBIES6CES6SS560AC 47 SS6ESGE BSP IF OTIZEPLCHPIDSEFIESPL4ABSOTS4EDSCBAOAEOCC79E 
407797 16266910691 954F5017069248074F 897D3706725B8074F836CB 70697248007 1F 7456 
{0797 \EZ6EB3B84FD33076C 4691 S4F DB 4057084 09F OF 402C 1 2BIESE4ESBBSSLSFABB4BPS 
/O7BSLEZ648006406FE70GF 7AFF 44000273078 76931 40C BOBS48AFF71600540110C00153 
/O7D31E268774BB897EC 1 D4S4SAFF2490F F6ACS2ED7 OF ACB2252F FISOSLOSE21S48AF F249A 
/O7F LIE2ZS9OFF6B0831407C176406FF30774F ASCS503EFO018774EBB9BCS5691154F 5017072 
/OBOF 1E263F 7AFFA77 OSF P6FF74C7B7B 36931 40CBOBS4A4FF7 18002401 10C01A47497089 
/O082D 1 D2S97BE63A401AS7TIIOPPESASO LASTS FOP AGSASASEPSS40C BOBSSA4FF7 1800254 
/08441E25940210C716E9815030471B8100B8706E24B0706F 2580A7706972680070348A420 
/08681E254B217041343DFF4893B840C S0B34297804B833324EB0E32424B8001373D013463D3é 
/08861E2501383B8690270792280B83478F F 4300004875489391 SOGO830B1LOOSS9OFFSGAZA 
/OBASOAZOOSE9003DS2FD4S0550EL8876 

/OBAE LESF3468FFS&9FC7OFDCI490A7OF DC 448347 OF BD701LOZLASOFBOCOATSESO2LCS47A0 
/OBCCLEZF100956906547E00 1 SOSO2BEOSOSFDS4F301590354F301 S4DDOSS70354F30123 
/OGSEALESFS54B206590354F301402A0C016A633B8 150202456901 05S02FD95038054620902 
/O90B1LE201502046901455808C S48SA0SOOFBS SOZOVSCASBSALAD102160463020A74C001 
/09261FE20566356401713014C74E056450204483A7 IBO4C4EIF403A1474E8534E176333 
/OPG4 LEZOSB344FFFSSSB01S24CCO7SEOS74SS002483A70CI63S46S303B 4FAASOFS 128865 
/097621E20013B550202483A74C0516351405918405718B8S90354F30140830944010001 
/OFBOLEZOSOOCOCT7T IL BOCOISSSSFF4ESS69004DCC4A4FFFFABDIZ4845S0034AD0970SEAOFFSB3 
/OFSELEQF40A4S1LS700E7DFFSSOZOSFF401713SFCEP9044DCC7TOOF7DFF34C 809 703EACFFAL 
/O9BCLEQF40A4512AAS SOQOSFF40171SFC48C0348SFF 48997 00F 7DFF 40001 2AABAS9037C 
/O9DALEQFS4F 3014401 0040000C71B001S4SFFFIEZSS4FFO74A0CSOBS40000469ED40D42B 
/O9F BLESFOB4S0020FBSBS590354F 301 44FF0040000C7180F F3400FF40210CS69ED70791240 
/OALE1E208040020F B8590354F 301 44EF 0040EF ORS9EF 70791 28040020F 3400FF 7180446 
/QAI4S LESOEF 4O1 LOCBESIOSS4F S01 402A0C 40D4S0C7IBLILZLZAOO7TITBOOL4E2Z0A701LEIF 
/OAS21E209DFF 4843007 00E7DFFS6407F7401713FC 7OOF7DFFE&YO7FFAASIOOSIFEGAOSB2 
/OA7OLEZOSOESOCOO7TOLE7DFFOL7BIEOL7TAS504 1 F4602637A693340CBOB347NFF 7180465 
/OAGE1LE2F0140210C3081 4FDB446B0040C SOB S400007NSE7ZAFF6FEDSZ0D460B40020F 384A 
fOAAC LESFS90354F301 402A0C 409F0F44470040C SOBSI000ZS9EF 40D460B40020F S4DEsSE 
/OACALIE2FO9S90354F 301 402A0C 4641 AS040ES0D6409FE70692080690670792080403D27 
/QAEBLE2ZF 134017 135645ALOF 9E40A7FBES9O3S4F 301 202A0CIOESODB42COB7VOSESDFFSC 
/0B061E204843006407F76409FE6906707 972080401 7137069228047F OF 4690070792029 
/0B241E20806407FF6409FEBBB0490740E 1 144B83A4839AC0641901401713401713401732 
/0B421E201397069228047F 0O6409F EADAAG2570354F 301 402A0C 40ESOD34870B 7OSE9DS2 
/OB601D1FFF64919014843006407F 76906707 9208040171 3706922B047F OF 66900701A 
/OB7DLE2E7920804407FF 46409F EB SBOSS0B40E1 1 4COOOKSO09FEL9OS40E1 L4COSL7O00004A 
/OBIBIELZESS 1LIOLAOAAGZS9IOSS4F301 40ZA0C 4049124401 0040000C71B00124A4FFS0F9 
/OBESOC2B210C469ED7079128040020F B8E3 

/OBC S1LE2BS40A804893EB8A7240C80489270771 JBOBSA72Z4I0BB04B92707F 1 ZE0OSOBFI7SA 
(OBES 1E2BB8A724940080498927079 1 O8O0BB40C SO0B24940005693140CBCBSP7EEGONSORBB4043 
/OCOL1IEICCSOB340003693340C BOB67EESOD40B BB 40020F 01801 B242B802A002A3D5333 
/OCIFLEGSFCBB242BE02D3A3080F BESS4é6EFFS5S57203472F FS69S03B407B0C4409F E3498 
/CCIDLE2BSGFF4B85701F47FF745EN4ESFOBS67005S97FF1B2D07 LF 74BB494E2 107034 BA49E 
/0C531E2848214839670412D371 1D30A070 1 3D4897S40700C S50302B83465S0274 AF Ba6526 
/OC771LE2ZB21D0S56720CC SSO2OBCB6SS600BSSBOCF DEBSI0454F5015701C464097FDB36)} 
0097 1E2B6419020864800B690640E1 144 CEQOSO2ZEF 37801 S50Z10BS40D40C717F126A35 
/OCBSLE2BES40E30CC76700D0745830CC706B2780744EFFC4407508BB307FE440750870 
/0CD31E2BB93429804B33324B07690270792280B 869334016074 0680EBREB 96920356450 
/OCFLLESBIL4F 9771 7FOPSOD40CE9004DCC44FFFF48D21 4180D701 ESDFF484300700E91 
/ODOF LESB7DFFS407F 740171 3F CE9044DCC7O0F 7DFF4&407FFAA7TLBLOOZI7DL1401713BA 
/O0D2D1E2834870048CO74AFFB44FA00CSS8CO74.4F FB 449001 74C7B7B36A8 569334014684 
/0D48 1E2B07A3644A1 007 48C07 4AFF7 4E2670697208057 304ED4 70692780471 LEE 1CIO4A 
/O0D671E2B816581124E266B0540171353F 844FD01 74C7B74FBB2420804A002ZA75S7D114C 
/0D87 1E28C60181637D4F DASO7F 4F 687 17D11340003693340CBOB34D40D01 6AACICEESA 
/ODAS1E2B00703F 36FFA7 0138 1 DS6A003428800838 0938 0074985E3B01 7DS60FBC34B11460 
/ODCSIE2BC90A3B60C 4371 166111A43747B 1 24FE0B8010107060D07030S0F0ZOCOEOAZS 
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/ODE11E28040B08106903707922806712707721 8034298048 1 0324RB0E706720808 84008 
/ODFF 1E3A550E203973391 1897 1390001384174E8496900635387079246807700Des3 43622 
/QE1LDIEZBFF4883A84893703F 47FF7 4EF BBS42480083D093D013A41670269700623A406D 
/OEZB1LE2QBI00C7700B 9343DFF4ES3A83943BFF 48932466027 4EF BB409F OF B97 177035592 
/0E591E2B6B407 177007 176035548807 17600885 SOSBOGEBDACCOS37CEADSSESBSAN1L4O 
/QE77 1 D2A0A4DC8717D307 1 7EOPEIO4S40E 1 1LS0AG4S4ALOCESESDCB4ACEOSS4ALOFTE SS SF 
JOEP4& LE2ZA74E05S6644A 1 O4E4D5 SSB024BSAS44A1LOFE4374COS7TADCOG4S4AL 0S ESP S9ED5C 
/OEB2ZIEZADFS44A104E31 4661 0483A644A1 O4E2B74C07C 64441 04 E2026E04641 901 644A40 
/OEDOLE2ZALOD7307D4F AF E&44A1 OCF S07ESFA7E900707 9208070 LF2Q80B 969FFINIF 2073 
/QEEE1E3980645901B9747B00B 96900884017 13645A10F 9E7 S8024EB7 SSOSEO4E7 BEC S2 
/OF OC 1LEZA035S85846C010C 4DC8690540E114645A044ES00CE4 SADFSESASDCBACEOS SS Ab2 
/OF 241 E2A044E2174E056645A044E 1 9S SS8024ESAG45A044E0F 74COS7E45A04S46E074D50 
/OF S&B 1 E2ACOS44A044FCBS44A20BBOCE44A20BR4DCB4CE0644A203B74E0S56645AZ20B679 
(OF $61D29555B802483A644A2Z0B874C057E44A20584D0C064 SA2Z04FD1BB401713644A43 
/OF631C2704F 940171364 SAQ0F9B8645A04C SS802F94F 7 04644A20BBS802F94AFETSS 

/ OF 9F 1E3640DB80F SGO2FDBS402A0CSFESC4S409F OF BS401 LOZ346BRB00703E9DFFOSO7EF BF 
/OFBDLES640D60F S802C8BAS44A08C754D80084 5A06F LO4FFFFAASO940 1 4FEBSOSB 1389 
/OF DB 1LES66407EF4S0CC 13243BFF 4884 703F 4AFF 6419207 4BF 6409DFBS746AF F641 920AB 
/OFF91E364884701E3DFF7 4EDBS74E 5088S 7804E0A0S02FD7 1 SBCO71SC40CFI4FFFF7456 
/1LOL7LEL893A81 502027 1 5B40715CCO1503010S03DFOSO2FEB4S40B 41 3A4456B074ESES? 
/10351E1814010074AD4E4448A04894B8 5481A122443FF3447 1 BABASSBEESBT4ASSBA462 
/ 10831 E18488E48921 370 1ES1FF1114E0102400003439 LAL 169005 9OQZE9FFADCOE99639 
/10711D174DDA648590648580484 1 00640FFDBSO 1 SB4DCOS6979F40E1141134431A1 44D 
/108E1E262F 19114FDC3400007 1 SD068 462248330 1 5D482140AB 4601 60BB6601370A27 
{ LOAC 1E26690A270469044B25635040E01 16901 SVO2R4BSATACOSHO7TORAS6SEBOLSOSS8Seai& 
/LOCALE2Z601 4F6356A974FF4FC6405918409761340F 4121 SO2ZO0IBBECC207031ASE226034 
/10E81E 269263591 4FF10S502025100070374F BS814E01032Z101 16201591 BSCCEZO70SFA 
/11061E171A482260926359760E3S902483A0703747CO04BSAG04S2B40ES747C00S83AS0 
/11241E1744000064800047680D7483A1 848A048A05902D501 SB7041086700C367FF D834 
/11421E1709D61848A048A0S902EB015B7061 086 7F FC326900C 30998GA4DC0747C00SE448 
/11$01E1722701F43FFA574FFD801 SF 60E$974C0041 1DOLSCOS3SBOCFF7OSF49FF LAFF LOA2 
/VITELZIF10116232F8449C 1A74AFCA743D0306142F 19101 1L6233E6FE 
/319S1E1F4CC074A0632064636320658801646357690063636364581 SO280703E976FFS4 
/LIBSLELF715D0240E01177004E1F69015902483A7 4C05B80703635B801 SOSSSBOL4FER1A 
/LIDLIEIFS630964FE030974FDC690005027F 3901 SDSFSB4B3A5 S0202483A74C0545355 
/LIEFLEZES64017135F02CB4CCO74E0S746390269F AE 2840741401 SOS8S5B01 SF 7IEOS CSS 
/L2CDLIELIFSSSBOZ4B3ASS5SO2Z02483A27804FCSOSS803403D1474EBSS4F BAGIOOBS69F Fal 
{1223 1E1FBBSCO2B834E81 S7OSEAOFFOSOSDF 4084124017 1395SD03F A641 F 205000123857 
/L2497 LE LFOSOQFB3464 1 2703EAOFF40A4 1240171 35A02FA40D01 2AA401 7ISBEBOE SCTE 
/LE67LELFCLILA7SO66FOO7FD4ADC 1690240E1 14408212044 DC 1 4B843900ALADAAL LES E0074~ 
/LESASIEIFEFOS4OEL L44CEQ6SA4E9004BSACOCOS4BOUPEF904SI0EILS4CEOSSAS1 5020424 
/L2ABLELFBS4CC7571 ODC249DFF 48821 46560074BDC4444700C LASO7TF7BASBP2Z4DC 74892 
/1ACLLELF43Q0AABE7 OSEPDFF4AB4300640F F7BB4CC757 1 ODB249DFF 48821 46000748093 
/L2DF LE2EC4444C00C3446B001 7OBBASB924DC 7AABHS41F 088871 7FFF7 1 E2Z0A4CCOSS89 
/12FDLIEZESA307FCS6904547E004017134CCO7 4E05A460 526F SEFSGOBZESBASFOSDTE46E 
/IBIBIELFBOOOCO1LS 1639214000070 ESSFFS90840E1 1440DF 188B403D19690346C0E11400 
/ISSPLTELF404B 1 SBBE6406F F5858C 46480038 8646800 1 BESCEO7SE0S4E5S55502483A74C055 
41357 1E1F574DC08820612561 1 7BB7 161006A0320626 10101 626A0C 67 40CAGAB0S7TEOLF 
(13751 ELFCS6ACO6CFADES431FF7 1 7F040A7 08EBS0EASEQSOAS821 G0BA70CI2BS2307F7F 
/1S93 ELF 4FECB840BA14403D14635801505858014F 6396701 F 3BFF40A8141A70BB6053 
/LOBLIEIFEA4O02C 1238408A1440B7196351701F SBF F408C14342CFFAD6357E5B8701LF3D8S 
/1L3CF LECGEFFASSCOZD9S5D03D640741 440991401 4F BD4201 SOBDESA0ABL4S14FF 70833375 
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Having thus described an embodiment of the inven- 
tion, it will now be appreciated that the objects of the 
invention have been fully achieved in realizing a com- 
pletely self contained, compact, modular plug-in disk 
file subsystem, and it will be understood by those skilled 
in the art that many changes in construction and widely 
differing embodiments and applications of the invention 
will suggest themselves without departing from the 
spirit and scope of the invention. The disclosures and 
description herein are purely illustrative and are not 
intended to be in any sense limiting. 

We claim: 

1. A rotating disk memory accessory subsystem mod- 
ule for attachment and use entirely within a housing of 
a host computer at one of a plurality of accessory plug- 
in slot locations originally provided for a single, sub- 
stantially flat electronics printed circuit accessory card, 
the slot location having predetermined actual length 
and height dimension constraints and a nominal width 
dimension constraint for a printed circuit accessory 
card, said width dimension constraint being defined by 
the distance between adjacent accessory plug-in slot 
locations, and said length and height dimension con- 
straints being limited by the internal dimensions of said 
housing, and each of the slot locations further having at 
least one multiple signal path receptacle aligned and 
extending longitudinally along a lower attachment sur- 


face providing electrical connection to data, address” 


and control buses of the host computer, said subsystem 
module including substrate means for supporting, align- 
ing and providing electrical interconnection of: 
at least one multiple signal path connector aligned 
and extending along an edge of said substrate for 
mating with said at least one multiple signal path 
receptacle thereby providing direct plug-in attach- 
ment, connection and use of said subsystem module 
with the host computer without cabling at said one 
slot location; 
a rotating disk assembly including a radially position- 
‘able head transducer for flying in close proximity 


to a data storage surface of at least one rotating 
data storage disk upon an air bearing created by 
rotation of said disk, and wherein the data storage 
surface lies in a plane which is substantially parallel — 
when the subsystem module is installed at the said 
one slot location to a plane defined by the length 
and height dimension constraints of the said one 
slot location and which plane passes through a 
longitudinal axis of the said at least one multiple 
signal path receptacle; 


electronics circuitry including: 


data transducer position control means for control- 
ling the radial position of the head transducer in 
relation to user data block locations on the data 
storage surface, 

disk user data controller means for controlling the 
formatting, storage and retrieval of user data 
blocks to and from the storage surface via the 
head transducer, and 

interface means connected to said at least one mul- 
tiple signal path connector, said data transducer 
position control means and said disk user data 
controller means for obtaining control signals 
and data blocks from the host computer for stor- 
age of said data blocks on the data surface, and 
for supplying control signals and retrieving data 
blocks from the data surface and sending said 
supplied control signals and retrieved data 
blocks to the host computer via electrical signal 
paths through the said connector and the said 
receptacle; 


wherein said substrate means, said connector, said 


rotating disk assembly, and said electronics cir- 
cuitry of the subsystem module are positioned en- 
tirely within the actual length and height dimen- 
sion constraints of the said one slot location en- 
tirely within said housing, and lie sufficiently 
within the width constraint thereof without verti- 
cal extension and overhang above adjacent slot 
locations so that slot locations of the host computer 
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situated directly adjacent to the said one slot loca- = for controlling operations of the user data controller 
tion are capable of receiving and being occupied by = means. 
additional structure providing said host computer 11. The disk file subsystem module set forth in claim 
with at least one additional accessory function 1 wherein the transducer position control means in- 
when the said subsystem module is installed at the 5 cludes track following servo means responsive to track 
said one slot location of the host computer. centerline position information prerecorded on the disk 
2. The disk file subsystem module set forth in claim 1 surface which is read by the head transducer for posi- 
wherein said signal connector provides direct plug in _ tioning and maintaining the head transducer in align- 
attachment and connection of the subsystem module to | ment with the centerline of each recorded data block 
power buses of said host computer which are available !° location on the data surface being followed during read 
at said one receptacle without cabling. and write operations, the track following servo means 
3. The disk file subsystem module set forth in claim 1 further including programmed digital microcomputer 
wherein said interface means further comprises a read' means for supervising operations thereof. 
only memory containing prestored basic input/output! | 12. The disk file subsystem module set forth in claim 
routines for direct access and execution by a central !5 11 wherein the data blocks are recorded within a multi- 
processing unit of said host computer so that when said _plicity of concentric data tracks and said track center- 
subsystem module is installed in said host computer and _line position information is prerecorded in a single servo | 
used thereby there is no need to add such routines tothe sector located between the end and beginning of each ; 
host operating system control program which controls __ concentric data track, and further comprising raw index 
operations of the central processing unit. 20 detector means operatively associated with a spindle of . 
4. The disk file subsystem module set forth in claim 1 _ said disk for detecting the beginning of the servo sector, | 
wherein said substrate means comprises a frame and a and timing means for signalling the beginning of the | 
small printed circuit board attached to said frame, said pani singe sad the servo sector has passed by the data - 
circuit board carrying sai i i - ucer : 
tor and said sections ciety a aad 25 13. A rotating disk memory accessory subsystem 
5. The disk file subsystem module set forth in claim 4 module for attachment and use entirely within a hous- 
wherein the rotating disk assembly is mounted to the 28 Of a host computer at one of a plurality of accessory 
frame in longitudinal alignment with the printed circuit Plug-in location originally provided for a single, sub- | 
board and extends to adjacent an end of the frame dis- stantially flat electronics printed circuit accessory card, 
tant from an end at which the connector is located. 30 the slot location having predetermined actual length | 
6. The disk file subsystem module set forth in claim § 4 height dimension constraints and a nominal width | 
wherein the transverse thickness of the rotating disk dimension constraint for a printed circuit accessory 


: ; i card, said width dimension constraint being defined by 
assembly is not substantially greater than the nominal the distance between adj t ry plug-in slot 


} 
ae po aise eae of said one slot location of 35 locations, and said length and height dimension con- | 
7. Tie disk file vabysieas nice sot Roribita ciaigs's Susie Deine lnited by the totermal Gemensous of seid | 
Sen ae cee mee A rn housing, and each of the slot locations further having at | 
printed circuit board ra or tgp oie Gontainike leer ot mallee See ~_ eierecevin 
prestored basic input/output routines for direct access ae ed dp tnrat pptactnae dlaiareoem peo | 
and eosapgn es Aawain — ae ou host 40 and control buses of the host computer, said subsystem 
computer so computer uses the subsystem module including: 
ace. Cas ee ee of the central support ——— for supporting, aligning and 
OESEENS peraun, : : P providing electrical interconnection of: . 
Peles pan ea hsuzhigies module set forth inclaim 1 4 rotating disk assembly including a radially position- 
cans, comprises a unitary able head transducer for flying in close proximity 


printed circuit board for mounting said head and disk to a data storage surface of at least one rotating 
assembly, said multiple signal path connector and said data storage disk upon an air bearing created by 
electronics circuitry. . rotation of said disk, and wherein the data storage 

9. The disk file subsystem module set forth in clam 1 surface lies in a plane which is substantially parallel 
wherein said rotating disk assembly includes two rotat- °° when the subsystem module is installed at the said 
ing data storage disks mounted to a common spindle for one slot location to a plane defined by the length 
rotation in planes substantially parallel to said plane and height dimension constraints of the said one 
defined by the length and height dimension constraints location and which plane passes through a longitu- 
of, and passing through the longitudinal axis of the dinal axis of the said at least one multiple signal 


receptacle at said one slot location when said module is 55 _—_—path receptacle, and 
installed thereat and four data transducer heads, there printed circuit board means for carrying electronics 


being a said transducer head in close proximity to each _Circuitry including: 
data storage surface and head selection circuitry forsaid = _—at least one multiple signal path edge connector 
rotating disk assembly and connected to said heads and aligned and extending along an edge of said 
to said disk user data controller means for electing a © printed circuit board means for mating with said 
particular head and disk surface for storage and re- at least one multiple signal path receptacle 
trieval of user data blocks on its associated data storage thereby providing direct plug-in attachment, 
surface. connection and use of said subsystem module 
10. The disk file subsystem module set forth in claim with the host computer without cabling at said 
1 wherein the user data controller means includes one slot location, and 7 
read/write channel electronics, a data separator, a data said electronics circuitry including: 
sequencer, a data block buffer memory, a memory con- data transducer position control means for con- 


troller and programmed digital microcomputer means trolling the radial position of the head trans- 
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ducer in relation to user data block locations 
on the data storage surface, 
disk user data controller means for controlling 
the formatting, storage and retrieval of user 


data blocks to and from the storage surface via 5 


the head transducer, and 

interface means connected to said at least one 
multiple signal path edge connector, said data 
transducer position control means and said 


disk user data controller means for obtaining 10 


control signals and data blocks from the host 
computer for storage of said data blocks on the" 
data surface, and for supplying control signals 
and retrieving data blocks from the data sur- 


face and sending said supplied control signals 15 


and retrieved data blocks to the host computer 
via electrical signal paths through the said 
connector and the said receptacle, 
wherein said support frame means, said rotating disk 
assembly, and said printed circuit board means 
including said edge connector and said electronics 
circuitry of the subsystem module are positioned 
entirely within the actual length and height dimen- 
sion constraints of the said one slot location en- 
tirely within said housing, location, and lie suffi- 
ciently within the width dimension constraint 
thereof without vertical extension and overhang 
above adjacent slot locations so that slot locations | 
of the host computer situated directly adjacent to | 
the said one slot location are capable of receiving | 


and being occupied by additional structure provid- 30 


ing said host computer with at least one additional 
accessory function when the said subsystem mod- 
ule is installed at the said one slot location of the 
host computer. 

14. The disk file subsystem module set forth in claim 
13 wherein the user data controller means includes 
read/write channel electronics, a data separator, a data . 
sequencer, a data block buffer memory, a memory con- 
troller and programmed digital microcomputer means 
for controlling operations of the user data controller ; 


means. 
15. The disk file subsystem module set forth in claim 
13 wherein the transducer position control means in- 


20, 
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cludes track following servo means responsive to track 
centerline position information prerecorded on the disk 
surface which is read by the head transducer for posi- 
tioning and maintaining the head transducer in align- 
ment with the centerline of each recorded data block 
location on the data surface being followed during read 
and write operations, the track following servo means 
further including programmed digital microcomputer 
means for supervising operations thereof. 
16. The disk file subsystem module set forth in claim 
15 wherein the data blocks are recorded within a multi- 
plicity of concentric data tracks and said track center- 
line position information is prerecorded in a single servo 
sector located between the end and beginning of each 
concentric data track, and further comprising raw index 
detector means operatively associated with a spindle of 
said disk for detecting the beginning of the servo sector, 
and timing means for signalling the beginning of the 
_data track after the servo sector has passed by the data 
i transducer head. 
17. The disk file subsystem module set forth in claim 
13 wherein the rotating disk assembly is mounted to the 
iframe in longitudinal alignment with the printed circuit 
‘board and extends to adjacent an end of the frame dis- 
‘tant from an end at which the connector is located. 
} 18. The disk file subsystem module set forth in claim 
:17 wherein the transverse thickness of the rotating disk 
iassembly is not substantially greater than the nominal 
; width dimension constraint of said one slot location of 
said host computer. 
; 19. The disk file subsystem module set forth in claim 
18 wherein the nominal width dimension constraint of 
the said one accessory card slot location of the host 
computer and wherein the maximum transverse thick- 
ness of the rotating disk assembly are approximately one 


inch. 

20. The disk file subsystem module set forth in claim 
13 wherein the electronics circuitry on the printed cir- 
cuit board means includes a memory containing pre- 
stored basic input/output routines for direct access and 
| execution by a central processor unit of said host com- 
puter so that the host computer uses the subsystem 


40' module without software modifications of the central 


processing unit’s operating system. 
se &¢ &© ¢@ 


